spaCy/spacy/tests/spans/test_span.py

40 lines
947 B
Python
Raw Normal View History

2015-04-07 02:52:25 +00:00
from __future__ import unicode_literals
2016-01-16 15:19:09 +00:00
from spacy.attrs import HEAD
from spacy.en import English
import numpy as np
2015-04-07 02:52:25 +00:00
import pytest
@pytest.fixture
2015-07-09 15:30:58 +00:00
def doc(EN):
return EN('This is a sentence. This is another sentence. And a third.')
2015-04-07 02:52:25 +00:00
2015-07-23 07:26:43 +00:00
@pytest.mark.models
2015-04-07 02:52:25 +00:00
def test_sent_spans(doc):
sents = list(doc.sents)
assert sents[0].start == 0
assert sents[0].end == 5
assert len(sents) == 3
assert sum(len(sent) for sent in sents) == len(doc)
2015-07-09 15:30:58 +00:00
2015-07-23 07:26:43 +00:00
@pytest.mark.models
2015-07-09 15:30:58 +00:00
def test_root(doc):
np = doc[2:4]
assert len(np) == 2
assert np.orth_ == 'a sentence'
assert np.root.orth_ == 'sentence'
2015-07-13 22:08:50 +00:00
assert np.root.head.orth_ == 'is'
2016-01-16 15:19:09 +00:00
def test_root2():
text = 'through North and South Carolina'
EN = English(parser=False)
doc = EN(text)
heads = np.asarray([[0, 3, -1, -2, -4]], dtype='int32')
doc.from_array([HEAD], heads.T)
south_carolina = doc[-2:]
assert south_carolina.root.text == 'Carolina'