2019-06-02 13:22:57 +03:00
|
|
|
# coding: utf8
|
|
|
|
from __future__ import unicode_literals
|
|
|
|
|
|
|
|
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",
|
2020-04-30 12:13:23 +03:00
|
|
|
"veintiuno",
|
|
|
|
"veintidós",
|
|
|
|
"veintitrés",
|
|
|
|
"veinticuatro",
|
|
|
|
"veinticinco",
|
|
|
|
"veintiséis",
|
|
|
|
"veintisiete",
|
|
|
|
"veintiocho",
|
|
|
|
"veintinueve",
|
2019-06-02 13:22:57 +03:00
|
|
|
"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}
|