结巴分词有前空格_jieba英文空格分词问题

针对jieba分词在遇到含有空格或特殊符号的关键词时无法正确处理的问题,可以通过修改jieba源码解决。将词典中的空格替换为@@,并调整正则表达式,但可能导致分词结果包含不需要的符号。期望只保留包含空格的中英文关键词,并去除emoji等特殊字符。
摘要由CSDN通过智能技术生成

1.对于关键词存在空格或者特殊符号的情况下,jieba无法分出该词

2.在github上找到了一个解决方案,修改jieba源码

__init__.py

免费分享,造损免责。

打开默认词典(根目录)或自定义词典,把所有用来间隔词频和词性的空格间隔符改成@@

(选用@@是因为一般关键词里遇到这个分隔符的几率比较小吧)

继续,打开jieba根目录下init.py搜索

re_han_default = re.compile("([\u4E00-\u9FD5a-zA-Z0-9+#&\._]+)", re.U)

改成

re_han_default = re.compile("(.+)", re.U)

搜索

re_userdict = re.compile('^(.+?)( [0-9]+)?( [a-z]+)?$', re.U)

改成

re_userdict = re.compile('^(.+?)(\u0040\u0040[0-9]+)?(\u0040\u0040[a-z]+)?$', re.U)

搜索

word, freq = line.split(' ')[:2]

改成

word, freq = line.split('\u0040\u0040')[:2]

补充:若用的全模式继续改。

搜索

re_han_cut_all = re.compile("([\u4E00-\u9FD5]+)",

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值