最近,本小白在学习文本分析中遇到了一个好用的库tidytextpy,
github地址:https://github.com/thunderhit/tidytextpy
是本论坛“邓旭东HIT”进行修改的,非常感谢添加这个有用的功能。
在运行示范代码后有报错:
from tidytextpy import get_stopwords
cn_stps = get_stopwords('chinese')
print(cn_stps[:20])
UnicodeDecodeError: 'gbk' codec can't decode byte 0x94 in position 94: illegal multibyte sequence
原因大致是转码问题,研究了一下源码:
def get_stopwords(language = "english"):
"""Get stopwords for a language.
language: 停用词语言。有"english"和"chinese"两种参数可供查询获取。
"""
cnpath = pathlib.Path(__file__).parent.joinpath('dictionary', 'chinese.txt')
enpath = pathlib.Path(__file__).parent.joinpath('dictionary', 'english.txt')
cn_stopwords = open(cnpath).read().splitlines()
en_stopwords = open(enpath).read().splitlines()
dict_info = {'english': en_stopwords,
'chinese': cn_stopwords}
return dict_info[language]
建议遇到这个问题可以考虑以下修改:
def get_stopwords(language = "chinese"):
cnpath = '你的目标停词本路径'
cn_stopwords = open(cnpath,'r',encoding="utf-8").read().splitlines()
dict_info = {'chinese': cn_stopwords}
return dict_info[language]
因为我是中文分析,英语的直接删掉了,所然后直接抄这个函数稍微一改就用了(lan)
ps:停词本建议可以网上搜一下某位朋友整理的去重合集