mirror of
https://github.com/explosion/spaCy.git
synced 2025-01-12 02:06:31 +03:00
Initially span.as_doc() was designed to return a view of the span's contents, as a Doc object. This was a nice idea, but it fails due to the token.idx property, which refers to the character offset within the string. In a span, the idx of the first token might not be 0. Because this data is different, we can't have a view --- it'll be inconsistent. This patch changes span.as_doc() to instead return a copy. The docs are updated accordingly. Closes #1537 * Update test for span.as_doc() * Make span.as_doc() return a copy. Closes #1537 * Document change to Span.as_doc()
This commit is contained in:
parent
72e4d3782a
commit
63b7accd74
|
@ -152,6 +152,9 @@ def test_span_as_doc(doc):
|
||||||
span = doc[4:10]
|
span = doc[4:10]
|
||||||
span_doc = span.as_doc()
|
span_doc = span.as_doc()
|
||||||
assert span.text == span_doc.text.strip()
|
assert span.text == span_doc.text.strip()
|
||||||
|
assert isinstance(span_doc, doc.__class__)
|
||||||
|
assert span_doc is not doc
|
||||||
|
assert span_doc[0].idx == 0
|
||||||
|
|
||||||
|
|
||||||
def test_span_string_label(doc):
|
def test_span_string_label(doc):
|
||||||
|
|
|
@ -14,7 +14,7 @@ from ..typedefs cimport flags_t, attr_t, hash_t
|
||||||
from ..attrs cimport attr_id_t
|
from ..attrs cimport attr_id_t
|
||||||
from ..parts_of_speech cimport univ_pos_t
|
from ..parts_of_speech cimport univ_pos_t
|
||||||
from ..util import normalize_slice
|
from ..util import normalize_slice
|
||||||
from ..attrs cimport IS_PUNCT, IS_SPACE
|
from ..attrs cimport *
|
||||||
from ..lexeme cimport Lexeme
|
from ..lexeme cimport Lexeme
|
||||||
from ..compat import is_config, basestring_
|
from ..compat import is_config, basestring_
|
||||||
from ..errors import Errors, TempErrors, Warnings, user_warning, models_warning
|
from ..errors import Errors, TempErrors, Warnings, user_warning, models_warning
|
||||||
|
@ -149,23 +149,32 @@ cdef class Span:
|
||||||
|
|
||||||
def as_doc(self):
|
def as_doc(self):
|
||||||
# TODO: fix
|
# TODO: fix
|
||||||
"""Create a `Doc` object view of the Span's data. This is mostly
|
"""Create a `Doc` object with a copy of the Span's data.
|
||||||
useful for C-typed interfaces.
|
|
||||||
|
|
||||||
RETURNS (Doc): The `Doc` view of the span.
|
RETURNS (Doc): The `Doc` copy of the span.
|
||||||
"""
|
"""
|
||||||
cdef Doc doc = Doc(self.doc.vocab)
|
cdef Doc doc = Doc(self.doc.vocab,
|
||||||
doc.length = self.end-self.start
|
words=[t.text for t in self],
|
||||||
doc.c = &self.doc.c[self.start]
|
spaces=[bool(t.whitespace_) for t in self])
|
||||||
doc.mem = self.doc.mem
|
array_head = [LENGTH, SPACY, LEMMA, ENT_IOB, ENT_TYPE]
|
||||||
doc.is_parsed = self.doc.is_parsed
|
if self.doc.is_tagged:
|
||||||
doc.is_tagged = self.doc.is_tagged
|
array_head.append(TAG)
|
||||||
|
# if doc parsed add head and dep attribute
|
||||||
|
if self.doc.is_parsed:
|
||||||
|
array_head.extend([HEAD, DEP])
|
||||||
|
# otherwise add sent_start
|
||||||
|
else:
|
||||||
|
array_head.append(SENT_START)
|
||||||
|
array = self.doc.to_array(array_head)
|
||||||
|
doc.from_array(array_head, array[self.start : self.end])
|
||||||
|
|
||||||
doc.noun_chunks_iterator = self.doc.noun_chunks_iterator
|
doc.noun_chunks_iterator = self.doc.noun_chunks_iterator
|
||||||
doc.user_hooks = self.doc.user_hooks
|
doc.user_hooks = self.doc.user_hooks
|
||||||
doc.user_span_hooks = self.doc.user_span_hooks
|
doc.user_span_hooks = self.doc.user_span_hooks
|
||||||
doc.user_token_hooks = self.doc.user_token_hooks
|
doc.user_token_hooks = self.doc.user_token_hooks
|
||||||
doc.vector = self.vector
|
doc.vector = self.vector
|
||||||
doc.vector_norm = self.vector_norm
|
doc.vector_norm = self.vector_norm
|
||||||
|
doc.tensor = self.doc.tensor[self.start : self.end]
|
||||||
for key, value in self.doc.cats.items():
|
for key, value in self.doc.cats.items():
|
||||||
if hasattr(key, '__len__') and len(key) == 3:
|
if hasattr(key, '__len__') and len(key) == 3:
|
||||||
cat_start, cat_end, cat_label = key
|
cat_start, cat_end, cat_label = key
|
||||||
|
|
|
@ -377,8 +377,8 @@ p
|
||||||
+h(2, "as_doc") Span.as_doc
|
+h(2, "as_doc") Span.as_doc
|
||||||
|
|
||||||
p
|
p
|
||||||
| Create a #[code Doc] object view of the #[code Span]'s data. Mostly
|
| Create a new #[code Doc] object corresponding to the #[code Span], with
|
||||||
| useful for C-typed interfaces.
|
| a copy of the data.
|
||||||
|
|
||||||
+aside-code("Example").
|
+aside-code("Example").
|
||||||
doc = nlp(u'I like New York in Autumn.')
|
doc = nlp(u'I like New York in Autumn.')
|
||||||
|
|
Loading…
Reference in New Issue
Block a user