西游记相关的分词,出现次数最高的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))

为了统计《西游记》中主要人物的出场次数,可以使用Python的jieba分词库来实现。首先,需要将《西游记》的文本数据加载到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、付费专栏及课程。

余额充值