Revert "Convert custom user_data to token extension format for Japanese tokenizer (#5652)" (#5665)

This reverts commit 1dd38191ec.
This commit is contained in:
Matthew Honnibal 2020-06-29 14:34:15 +02:00 committed by GitHub
parent 1dd38191ec
commit 2d715451a2
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 15 additions and 35 deletions

View File

@ -145,7 +145,8 @@ class JapaneseTokenizer(DummyTokenizer):
dtokens, spaces = get_dtokens_and_spaces(dtokens, text) dtokens, spaces = get_dtokens_and_spaces(dtokens, text)
# create Doc with tag bi-gram based part-of-speech identification rules # create Doc with tag bi-gram based part-of-speech identification rules
words = [dtoken.surface for dtoken in dtokens] words, tags, inflections, lemmas, readings, sub_tokens_list = zip(*dtokens) if dtokens else [[]] * 6
sub_tokens_list = list(sub_tokens_list)
doc = Doc(self.vocab, words=words, spaces=spaces) doc = Doc(self.vocab, words=words, spaces=spaces)
next_pos = None # for bi-gram rules next_pos = None # for bi-gram rules
for idx, (token, dtoken) in enumerate(zip(doc, dtokens)): for idx, (token, dtoken) in enumerate(zip(doc, dtokens)):
@ -157,14 +158,14 @@ class JapaneseTokenizer(DummyTokenizer):
token.pos, next_pos = resolve_pos( token.pos, next_pos = resolve_pos(
token.orth_, token.orth_,
dtoken.tag, dtoken.tag,
dtokens[idx + 1].tag if idx + 1 < len(dtokens) else None tags[idx + 1] if idx + 1 < len(tags) else None
) )
# if there's no lemma info (it's an unk) just use the surface # if there's no lemma info (it's an unk) just use the surface
token.lemma_ = dtoken.lemma if dtoken.lemma else dtoken.surface token.lemma_ = dtoken.lemma if dtoken.lemma else dtoken.surface
doc.user_data[('._.', 'inflection', token.idx, None)] = dtoken.inf
doc.user_data[('._.', 'reading_form', token.idx, None)] = dtoken.reading doc.user_data["inflections"] = inflections
doc.user_data[('._.', 'sub_tokens', token.idx, None)] = dtoken.sub_tokens doc.user_data["reading_forms"] = readings
doc.user_data[('._.', 'lemma', token.idx, None)] = token.lemma_ doc.user_data["sub_tokens"] = sub_tokens_list
return doc return doc

View File

@ -5,18 +5,6 @@ import pytest
from ...tokenizer.test_naughty_strings import NAUGHTY_STRINGS from ...tokenizer.test_naughty_strings import NAUGHTY_STRINGS
from spacy.lang.ja import Japanese, DetailedToken from spacy.lang.ja import Japanese, DetailedToken
from spacy.tokens import Token
from spacy.tokens.underscore import Underscore
@pytest.fixture(scope="function", autouse=True)
def clean_underscore():
# reset the Underscore object after the test, to avoid having state copied across tests
yield
Underscore.doc_extensions = {}
Underscore.span_extensions = {}
Underscore.token_extensions = {}
# fmt: off # fmt: off
TOKENIZER_TESTS = [ TOKENIZER_TESTS = [
@ -139,33 +127,24 @@ def test_ja_tokenizer_sub_tokens(ja_tokenizer, text, sub_tokens_list_a, sub_toke
nlp_b = Japanese(meta={"tokenizer": {"config": {"split_mode": "B"}}}) nlp_b = Japanese(meta={"tokenizer": {"config": {"split_mode": "B"}}})
nlp_c = Japanese(meta={"tokenizer": {"config": {"split_mode": "C"}}}) nlp_c = Japanese(meta={"tokenizer": {"config": {"split_mode": "C"}}})
doc = ja_tokenizer(text) assert ja_tokenizer(text).user_data["sub_tokens"] == sub_tokens_list_a
doc_a = nlp_a(text) assert nlp_a(text).user_data["sub_tokens"] == sub_tokens_list_a
doc_b = nlp_b(text) assert nlp_b(text).user_data["sub_tokens"] == sub_tokens_list_b
doc_c = nlp_c(text) assert nlp_c(text).user_data["sub_tokens"] == sub_tokens_list_c
Token.set_extension("sub_tokens", default="")
assert [t._.sub_tokens for t in doc] == sub_tokens_list_a
assert [t._.sub_tokens for t in doc_a] == sub_tokens_list_a
assert [t._.sub_tokens for t in doc_b] == sub_tokens_list_b
assert [t._.sub_tokens for t in doc_c] == sub_tokens_list_c
@pytest.mark.parametrize("text,inflections,reading_forms", @pytest.mark.parametrize("text,inflections,reading_forms",
[ [
( (
"取ってつけた", "取ってつけた",
["五段-ラ行,連用形-促音便", "", "下一段-カ行,連用形-一般", "助動詞-タ,終止形-一般"], ("五段-ラ行,連用形-促音便", "", "下一段-カ行,連用形-一般", "助動詞-タ,終止形-一般"),
["トッ", "", "ツケ", ""], ("トッ", "", "ツケ", ""),
), ),
] ]
) )
def test_ja_tokenizer_inflections_reading_forms(ja_tokenizer, text, inflections, reading_forms): def test_ja_tokenizer_inflections_reading_forms(ja_tokenizer, text, inflections, reading_forms):
Token.set_extension("inflection", default="") assert ja_tokenizer(text).user_data["inflections"] == inflections
Token.set_extension("reading_form", default="") assert ja_tokenizer(text).user_data["reading_forms"] == reading_forms
doc = ja_tokenizer(text)
assert [t._.inflection for t in doc] == inflections
assert [t._.reading_form for t in doc] == reading_forms
def test_ja_tokenizer_emptyish_texts(ja_tokenizer): def test_ja_tokenizer_emptyish_texts(ja_tokenizer):