NLTK正则表达式令牌生成器在正则表达式中不能与小数点配合良好

NLTK正则表达式令牌生成器在正则表达式中不能与小数点配合良好,第1张

NLTK正则表达式令牌生成器在正则表达式中不能与小数点配合良好

罪魁祸首是:

w+([-']w+)*

w+
匹配数量和因为没有
.
出现,这将只匹配
3
3.14
。将选项稍微移动一点,使其
$?d+(.d+)?%?
在上述正则表达式部分之前(以便首先尝试在数字格式上进行匹配):

(?x)([A-Z].)+|$?d+(.d+)?%?|w+([-']w+)*|[+/-@&*]

regex101演示

或以扩展形式:

pattern = r'''(?x)    # set flag to allow verbose regexps   ([A-Z].)+         # abbreviations, e.g. U.S.A.   | $?d+(.d+)?%? # numbers, incl. currency and percentages   | w+([-']w+)*    # words w/ optional internal hyphens/apostrophe   | [+/-@&*]        # special characters with meanings '''


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5498860.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-12
下一篇 2022-12-12

发表评论

登录后才能评论

评论列表(0条)

保存