python最大分词_python运用jieba库统计《西游记》中相关分词出现次数最高的20个...

import jieba

txt = open("西游记.txt", "r", encoding='utf-8').read()

words = jieba.lcut(txt) # 使用精确模式对文本进行分词

counts = {} # 通过键值对的形式存储词语及其出现的次数

for word in words:

if len(word) == 1:

continue

elif word == "大圣" or word=="老孙" or word=="行者" or word=="孙大圣" or word=="孙行者" or word=="猴王" or word=="悟空" or word=="齐天大圣" or word=="猴子":

rword = "孙悟空"

elif word == "师父" or word == "三藏" or word=="圣僧":

rword = "唐僧"

elif word == "呆子" or word=="八戒" or word=="老猪":

rword = "猪八戒"

elif word=="沙和尚":

rword="沙僧"

elif word == "妖精" or word=="妖魔" or word=="妖道":

rword = "妖怪"

elif word=="佛祖":

rword="如来"

elif word=="三太子":

rword="白马"

else:

rword = word

counts[rword] = counts.get(rword,0) + 1

items = list(counts.items())#将键值对转换成列表

items.sort(key=lambda x: x[1], reverse=True) # 根据词语出现的次数进行从大到小排序

for i in range(20):

word, count = items[i]

print("{0:<10}{1:>5}".format(word, count))

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
为了统计西游记主要人物的出场次数,可以使用Pythonjieba分词来实现。首先,需要将《西游记》的文本数据加载到Python。然后,使用jieba分词对文本进行分词处理。 首先,我们需要下载并安装jieba分词。可以使用以下命令安装: ``` pip install jieba ``` 接下来,导入jieba,并加载《西游记》的文本数据: ```python import jieba # 加载《西游记》的文本数据 with open('xiyouji.txt', 'r', encoding='utf-8') as f: text = f.read() ``` 然后,使用jieba进行分词。为了去除一些停用词(如标点符号、连词等),可以加载自定义的停用词列表,并设置为jieba的停用词表: ```python # 加载停用词表 stopwords = [',', '。', '、', '的', '了', '和', '是', '在', '他', '她', '他们', '我们'] # 设置jieba的停用词表 jieba.set_stop_words(stopwords) # 使用jieba进行分词 words = jieba.lcut(text) ``` 接下来,统计主要人物出现次数。我们可以创建一个字典来保存每个人物的出现次数,并遍历分词结果进行统计: ```python # 创建一个字典保存人物出现次数 character_count = {} # 遍历分词结果统计人物出现次数 for word in words: if word in character_count: character_count[word] += 1 else: character_count[word] = 1 ``` 最后,根据人物出现次数进行排序,并输出统计结果: ```python # 根据人物出现次数进行排序 sorted_character_count = sorted(character_count.items(), key=lambda x: x[1], reverse=True) # 输出主要人物及其出现次数 for character, count in sorted_character_count[:10]: print(character, count) ``` 以上就是使用jieba分词统计西游记主要人物出场次数的方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值