Python 中文词频分析——红楼梦人物出场次数

2024-02-19 08:40

本文主要是介绍Python 中文词频分析——红楼梦人物出场次数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本篇文档,带大家用Python做一下词频统计

本章需要用到Python的jieba模块
jieba模块是一个经典的用于中文分词的模块

首先呢 我们需要读取文章的内容,并用jieba库的lcut进行分词

import jieba# 读取红楼梦的文本内容
txt = open('红楼梦.txt', 'r', encoding='utf-8').read()
# 运用jieba库对文本内容进行分词
words = jieba.lcut(txt)

然后 我们去统计人名的出现次数
这里需要分析什么词语是人名,我们去创建一个文档,当做字典存储人名信息
人名还会有其他的表示,我们将它转化成一样的名字

# 初始化count字典 用于存放人名出现频率
counts = {}
# 读取红楼梦人名信息
names = open('人名.txt', 'r', encoding='utf-8').read().split('、')
# 对分词数据进行筛选 将不需要的数据跳过  只保存有效数据
for word in words:if len(word) == 1:continueelif word == '贾母' or word == '老太太':word = '贾母'elif word in '贾珍—尤氏'.split('—'):word = '贾珍'elif word in '贾蓉—秦可卿'.split('-'):word = '贾蓉'elif word in '贾赦—邢夫人'.split('-'):word = '贾赦'elif word in '贾政—王夫人'.split('-'):word = '贾政'elif word in '袭人-蕊珠'.split('-'):word = '袭人'elif word in '贾琏—王熙凤'.split('-'):word = '贾琏'elif word in '紫鹃-鹦哥'.split('-'):word = '紫鹃'elif word in '翠缕-缕儿'.split('-'):word = '翠缕'elif word in '香菱-甄英莲'.split('-'):word = '香菱'elif word in '豆官-豆童'.split('-'):word = '豆官'elif word in '薛蝌—邢岫烟'.split('-'):word = '薛蝌'elif word in '薛蟠—夏金桂'.split('-'):word = '薛蟠'elif word in '贾宝玉-宝玉'.split('-'):word = '贾宝玉'elif word in '林黛玉-林姑娘-黛玉'.split('-'):word = '林黛玉'if word not in names:continuecounts[word] = counts.get(word, 0)+1

最后我们将数据排序整理一下

# 将人名按照次数排序 降序
items = list(counts.items())
# 排序规则 以次数为参考进行排序
items.sort(key=lambda x: x[1], reverse=True)

完整代码如下:

import jieba# 读取红楼梦的文本内容
txt = open('红楼梦.txt', 'r', encoding='utf-8').read()
# 运用jieba库对文本内容进行分词
words = jieba.lcut(txt)
# 初始化count字典 用于存放人名出现频率
counts = {}
# 读取红楼梦人名信息
names = open('人名.txt', 'r', encoding='utf-8').read().split('、')
# 对分词数据进行筛选 将不需要的数据跳过  只保存有效数据
for word in words:if len(word) == 1:continueelif word == '贾母' or word == '老太太':word = '贾母'elif word in '贾珍—尤氏'.split('—'):word = '贾珍'elif word in '贾蓉—秦可卿'.split('-'):word = '贾蓉'elif word in '贾赦—邢夫人'.split('-'):word = '贾赦'elif word in '贾政—王夫人'.split('-'):word = '贾政'elif word in '袭人-蕊珠'.split('-'):word = '袭人'elif word in '贾琏—王熙凤'.split('-'):word = '贾琏'elif word in '紫鹃-鹦哥'.split('-'):word = '紫鹃'elif word in '翠缕-缕儿'.split('-'):word = '翠缕'elif word in '香菱-甄英莲'.split('-'):word = '香菱'elif word in '豆官-豆童'.split('-'):word = '豆官'elif word in '薛蝌—邢岫烟'.split('-'):word = '薛蝌'elif word in '薛蟠—夏金桂'.split('-'):word = '薛蟠'elif word in '贾宝玉-宝玉'.split('-'):word = '贾宝玉'elif word in '林黛玉-林姑娘-黛玉'.split('-'):word = '林黛玉'if word not in names:continuecounts[word] = counts.get(word, 0)+1# 将人名按照次数排序 降序
items = list(counts.items())
# 排序规则 以次数为参考进行排序
items.sort(key=lambda x: x[1], reverse=True)
# print(items)
print('出现次数最多的是:', items[0][0], '出现了:', items[0][1], '次')
print('出现次数最少的是:', items[-1][0], '出现了:', items[-1][1], '次')
for item in items:print(item[0], '出现了:', item[1], '次')

效果图如下:
在这里插入图片描述
Python问题解答私信我

这篇关于Python 中文词频分析——红楼梦人物出场次数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/724133

相关文章

MySQL表锁、页面锁和行锁的作用及其优缺点对比分析

《MySQL表锁、页面锁和行锁的作用及其优缺点对比分析》MySQL中的表锁、页面锁和行锁各有特点,适用于不同的场景,表锁锁定整个表,适用于批量操作和MyISAM存储引擎,页面锁锁定数据页,适用于旧版本... 目录1. 表锁(Table Lock)2. 页面锁(Page Lock)3. 行锁(Row Lock

使用Python创建一个能够筛选文件的PDF合并工具

《使用Python创建一个能够筛选文件的PDF合并工具》这篇文章主要为大家详细介绍了如何使用Python创建一个能够筛选文件的PDF合并工具,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录背景主要功能全部代码代码解析1. 初始化 wx.Frame 窗口2. 创建工具栏3. 创建布局和界面控件4

一文详解如何在Python中使用Requests库

《一文详解如何在Python中使用Requests库》:本文主要介绍如何在Python中使用Requests库的相关资料,Requests库是Python中常用的第三方库,用于简化HTTP请求的发... 目录前言1. 安装Requests库2. 发起GET请求3. 发送带有查询参数的GET请求4. 发起PO

Python与DeepSeek的深度融合实战

《Python与DeepSeek的深度融合实战》Python作为最受欢迎的编程语言之一,以其简洁易读的语法、丰富的库和广泛的应用场景,成为了无数开发者的首选,而DeepSeek,作为人工智能领域的新星... 目录一、python与DeepSeek的结合优势二、模型训练1. 数据准备2. 模型架构与参数设置3

Python进行PDF文件拆分的示例详解

《Python进行PDF文件拆分的示例详解》在日常生活中,我们常常会遇到大型的PDF文件,难以发送,将PDF拆分成多个小文件是一个实用的解决方案,下面我们就来看看如何使用Python实现PDF文件拆分... 目录使用工具将PDF按页数拆分将PDF的每一页拆分为单独的文件将PDF按指定页数拆分根据页码范围拆分

Python中常用的四种取整方式分享

《Python中常用的四种取整方式分享》在数据处理和数值计算中,取整操作是非常常见的需求,Python提供了多种取整方式,本文为大家整理了四种常用的方法,希望对大家有所帮助... 目录引言向零取整(Truncate)向下取整(Floor)向上取整(Ceil)四舍五入(Round)四种取整方式的对比综合示例应

python 3.8 的anaconda下载方法

《python3.8的anaconda下载方法》本文详细介绍了如何下载和安装带有Python3.8的Anaconda发行版,包括Anaconda简介、下载步骤、安装指南以及验证安装结果,此外,还介... 目录python3.8 版本的 Anaconda 下载与安装指南一、Anaconda 简介二、下载 An

Python自动化处理手机验证码

《Python自动化处理手机验证码》手机验证码是一种常见的身份验证手段,广泛应用于用户注册、登录、交易确认等场景,下面我们来看看如何使用Python自动化处理手机验证码吧... 目录一、获取手机验证码1.1 通过短信接收验证码1.2 使用第三方短信接收服务1.3 使用ADB读取手机短信1.4 通过API获取

python安装whl包并解决依赖关系的实现

《python安装whl包并解决依赖关系的实现》本文主要介绍了python安装whl包并解决依赖关系的实现,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录一、什么是whl文件?二、我们为什么需要使用whl文件来安装python库?三、我们应该去哪儿下

Python脚本实现图片文件批量命名

《Python脚本实现图片文件批量命名》这篇文章主要为大家详细介绍了一个用python第三方库pillow写的批量处理图片命名的脚本,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言源码批量处理图片尺寸脚本源码GUI界面源码打包成.exe可执行文件前言本文介绍一个用python第三方库pi