mirror of
https://github.com/explosion/spaCy.git
synced 2025-01-28 18:24:08 +03:00
5861308910
Handle tokenizer special cases more generally by using the Matcher internally to match special cases after the affix/token_match tokenization is complete. Instead of only matching special cases while processing balanced or nearly balanced prefixes and suffixes, this recognizes special cases in a wider range of contexts: * Allows arbitrary numbers of prefixes/affixes around special cases * Allows special cases separated by infixes Existing tests/settings that couldn't be preserved as before: * The emoticon '")' is no longer a supported special case * The emoticon ':)' in "example:)" is a false positive again When merged with #4258 (or the relevant cache bugfix), the affix and token_match properties should be modified to flush and reload all special cases to use the updated internal tokenization with the Matcher.
49 lines
1.5 KiB
Python
49 lines
1.5 KiB
Python
# coding: utf-8
|
|
from __future__ import unicode_literals
|
|
|
|
import sys
|
|
import pytest
|
|
|
|
|
|
def test_tokenizer_handles_emoticons(tokenizer):
|
|
# Tweebo challenge (CMU)
|
|
text = """:o :/ :'( >:o (: :) >.< XD -__- o.O ;D :-) @_@ :P 8D :1 >:( :D =| :> ...."""
|
|
tokens = tokenizer(text)
|
|
assert tokens[0].text == ":o"
|
|
assert tokens[1].text == ":/"
|
|
assert tokens[2].text == ":'("
|
|
assert tokens[3].text == ">:o"
|
|
assert tokens[4].text == "(:"
|
|
assert tokens[5].text == ":)"
|
|
assert tokens[6].text == ">.<"
|
|
assert tokens[7].text == "XD"
|
|
assert tokens[8].text == "-__-"
|
|
assert tokens[9].text == "o.O"
|
|
assert tokens[10].text == ";D"
|
|
assert tokens[11].text == ":-)"
|
|
assert tokens[12].text == "@_@"
|
|
assert tokens[13].text == ":P"
|
|
assert tokens[14].text == "8D"
|
|
assert tokens[15].text == ":1"
|
|
assert tokens[16].text == ">:("
|
|
assert tokens[17].text == ":D"
|
|
assert tokens[18].text == "=|"
|
|
assert tokens[19].text == ":>"
|
|
assert tokens[20].text == "...."
|
|
|
|
|
|
@pytest.mark.parametrize("text,length", [("108)", 2), ("XDN", 1)])
|
|
def test_tokenizer_excludes_false_pos_emoticons(tokenizer, text, length):
|
|
tokens = tokenizer(text)
|
|
assert len(tokens) == length
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
"text,length", [("can you still dunk?🍕🍔😵LOL", 8), ("i💙you", 3), ("🤘🤘yay!", 4)]
|
|
)
|
|
def test_tokenizer_handles_emoji(tokenizer, text, length):
|
|
# These break on narrow unicode builds, e.g. Windows
|
|
if sys.maxunicode >= 1114111:
|
|
tokens = tokenizer(text)
|
|
assert len(tokens) == length
|