2017-03-12 15:07:28 +03:00
|
|
|
# coding: utf8
|
2017-01-08 22:40:33 +03:00
|
|
|
from __future__ import unicode_literals
|
|
|
|
|
2017-05-08 16:49:56 +03:00
|
|
|
from ..language_data.punctuation import ALPHA_LOWER, LIST_ELLIPSES, QUOTES
|
|
|
|
from ..language_data.punctuation import ALPHA_UPPER, LIST_QUOTES, UNITS
|
|
|
|
from ..language_data.punctuation import CURRENCY, LIST_PUNCT, ALPHA, _QUOTES
|
|
|
|
|
|
|
|
|
|
|
|
_currency_symbols = r"\$ ¢ £ € ¥ ฿"
|
2017-01-14 17:51:59 +03:00
|
|
|
|
|
|
|
|
2017-01-14 18:30:11 +03:00
|
|
|
TOKENIZER_PREFIXES = (
|
|
|
|
[r'\+'] +
|
|
|
|
LIST_PUNCT +
|
|
|
|
LIST_ELLIPSES +
|
2017-05-08 16:49:56 +03:00
|
|
|
LIST_QUOTES)
|
|
|
|
|
2017-01-14 18:30:11 +03:00
|
|
|
|
2017-01-14 17:51:59 +03:00
|
|
|
TOKENIZER_SUFFIXES = (
|
|
|
|
LIST_PUNCT +
|
|
|
|
LIST_ELLIPSES +
|
|
|
|
LIST_QUOTES +
|
|
|
|
[
|
|
|
|
r'(?<=[0-9])\+',
|
|
|
|
r'(?<=°[FfCcKk])\.',
|
|
|
|
r'(?<=[0-9])(?:{c})'.format(c=CURRENCY),
|
|
|
|
r'(?<=[0-9])(?:{u})'.format(u=UNITS),
|
2017-05-08 16:49:56 +03:00
|
|
|
r'(?<=[{al}{p}{c}(?:{q})])\.'.format(al=ALPHA_LOWER, p=r'%²\-\)\]\+', q=QUOTES, c=_currency_symbols),
|
|
|
|
r'(?<=[{al})])-e'.format(al=ALPHA_LOWER)])
|
|
|
|
|
2017-01-14 17:51:59 +03:00
|
|
|
|
|
|
|
TOKENIZER_INFIXES = (
|
|
|
|
LIST_ELLIPSES +
|
|
|
|
[
|
|
|
|
r'(?<=[{al}])\.(?=[{au}])'.format(al=ALPHA_LOWER, au=ALPHA_UPPER),
|
|
|
|
r'(?<=[{a}]),(?=[{a}])'.format(a=ALPHA),
|
|
|
|
r'(?<=[{a}"])[:<>=](?=[{a}])'.format(a=ALPHA),
|
|
|
|
r'(?<=[{a}])--(?=[{a}])'.format(a=ALPHA),
|
|
|
|
r'(?<=[{a}]),(?=[{a}])'.format(a=ALPHA),
|
2017-05-08 16:49:56 +03:00
|
|
|
r'(?<=[{a}])([{q}\)\]\(\[])(?=[\-{a}])'.format(a=ALPHA, q=_QUOTES.replace("'", "").strip().replace(" ", ""))])
|