mirror of
https://github.com/explosion/spaCy.git
synced 2025-01-12 18:26:30 +03:00
db55577c45
* Remove unicode declarations * Remove Python 3.5 and 2.7 from CI * Don't require pathlib * Replace compat helpers * Remove OrderedDict * Use f-strings * Set Cython compiler language level * Fix typo * Re-add OrderedDict for Table * Update setup.cfg * Revert CONTRIBUTING.md * Revert lookups.md * Revert top-level.md * Small adjustments and docs [ci skip]
57 lines
941 B
Python
57 lines
941 B
Python
from ...attrs import LIKE_NUM
|
|
|
|
|
|
_num_words = [
|
|
"cero",
|
|
"uno",
|
|
"dos",
|
|
"tres",
|
|
"cuatro",
|
|
"cinco",
|
|
"seis",
|
|
"siete",
|
|
"ocho",
|
|
"nueve",
|
|
"diez",
|
|
"once",
|
|
"doce",
|
|
"trece",
|
|
"catorce",
|
|
"quince",
|
|
"dieciséis",
|
|
"diecisiete",
|
|
"dieciocho",
|
|
"diecinueve",
|
|
"veinte",
|
|
"treinta",
|
|
"cuarenta",
|
|
"cincuenta",
|
|
"sesenta",
|
|
"setenta",
|
|
"ochenta",
|
|
"noventa",
|
|
"cien",
|
|
"mil",
|
|
"millón",
|
|
"billón",
|
|
"trillón",
|
|
]
|
|
|
|
|
|
def like_num(text):
|
|
if text.startswith(("+", "-", "±", "~")):
|
|
text = text[1:]
|
|
text = text.replace(",", "").replace(".", "")
|
|
if text.isdigit():
|
|
return True
|
|
if text.count("/") == 1:
|
|
num, denom = text.split("/")
|
|
if num.isdigit() and denom.isdigit():
|
|
return True
|
|
if text.lower() in _num_words:
|
|
return True
|
|
return False
|
|
|
|
|
|
LEX_ATTRS = {LIKE_NUM: like_num}
|