Python实战:小说分词统计-数据可视化

在这篇博客中,我们将利用Python的jiebamatplotlib库,对经典小说《战争与和平》进行中文词语分析,统计小说中出现最多的10个人名,并以柱形图的形式展示结果。我们会特别处理一些别名,使统计结果更为准确。

步骤概览

具体实现

读取文本数据 : 我们首先将《战争与和平》的文本文件读入程序中。这里假设文件名为war_and_peace.txt并且位于当前工作目录。

使用jieba进行分词jieba是一个中文分词工具,我们使用它将整篇文章分割成一个个单词。

统计人名出现次数 : 我们定义了一个包含主要人名的列表,并使用Counter对这些人名在分词结果中的出现次数进行统计。

合并别名: 为了统计的准确性,我们将一些别名合并到相应的人名。例如,"公爵"计入"安德烈","小姐"计入"娜塔莎","伯爵"计入"皮埃尔"。

绘制统计图表 : 使用matplotlib绘制柱形图,展示出现次数最多的10个人名及其出现次数。

结果展示

运行上述代码后,我们得到一张柱形图,显示了《战争与和平》中出现次数最多的10个人名及其出现次数。这种可视化方法可以帮助我们更直观地理解小说中主要人物的出场频率和重要性。

总结

通过这篇博客,我们展示了如何利用Python的jiebamatplotlib库对中文文本进行词语分析,并绘制统计图表。希望这篇博客能对你有所帮助,如果有任何问题或建议,欢迎留言讨论!


请确保在运行代码前已安装必要的Python库:

sh 复制代码
pip install jieba matplotlib

并将《战争与和平》的文本文件命名为war_and_peace.txt,放置在当前工作目录中。

程序

👉更多项目,点我查看

相关推荐
aliceDingYM42 分钟前
Linux python3.6安装mayavi报错
linux·python·ui
MarkHD3 小时前
javascript 常见设计模式
开发语言·javascript·设计模式
海盗猫鸥3 小时前
C++入门基础篇(1)
开发语言·c++·学习
专注成就自我3 小时前
java使用easypoi模版导出word详细步骤
java·开发语言·word
.生产的驴4 小时前
SpringBoot AOP切入点表达式
spring boot·后端·python
多多*4 小时前
SpringBoot 启动流程六
java·开发语言·spring boot·后端·spring
让你三行代码QAQ4 小时前
SpringSecurity初始化过程
java·开发语言
逆水寻舟4 小时前
算法学习记录2
python·学习·算法
Mr_Richard4 小时前
Java动态代理的实现方式
java·开发语言
B站计算机毕业设计超人5 小时前
计算机毕业设计Python深度学习美食推荐系统 美食可视化 美食数据分析大屏 美食爬虫 美团爬虫 机器学习 大数据毕业设计 Django Vue.js
大数据·python·深度学习·机器学习·数据分析·课程设计·推荐算法