项目起因及意义

起初在浏览知乎时看见一篇文章觉得很有意思(用Python分析《红楼梦》),此文章较长,题主采用了一系列方法分析红楼梦前八十回和后四十回是否为同一个人所写,虽然题主贴上了部分实现的截图,我就想试着来实现一遍,但由于目前能力有限,一些机器学习算法不够了解,加上python又是刚刚学,所以我打算先结合《Python语言程序设计基础》这本书上的例子—-《三国演义》人物出场统计来作为此系列博客第一篇,后续等能力足矣会陆陆续续补上。

前期准备

三国里人物众多,我们需要对人物出场次数统计,中文文章需要分词才能进行词频统计,这里我们用到第三方库jieba,这里我就不提供下载方法了,然后我们需要《三国演义》的电子书网上都有,很容易下载。

项目进行

  1. 将文本数据导入pycharm
import jieba
txt = open("三国演义.txt", "r", encoding="gb18030").read()


这里的编码格式一开始我是按照书上‘utf-8’格式读取,发现会乱码,后来在pycharm里面用‘gbk’格式能读出文本内容,但是个别字符识别不出来,就去百度到“gb18030”比gbk范围更广,这里我成功读入。如果你此时还是读入不了可以写成下面形式

txt = open("三国演义.txt", "r", encoding="gb18030",errors="ignore").read()

2.完整代码实现

import jieba
excludes = {"将军", "却说", "荆州", "二人", "不可", "不能", "如此", "商议", "如何", "主公", "军士", "左右", "军马", "引兵", "次日", "大喜", "天下", "东吴", "于是", "今日", "不敢", "魏兵","人马", "陛下", "一人"}
txt = open("三国演义.txt", "r", encoding="gbk").read()
words = jieba.lcut(txt)
counts = {}
for word in words:if len(word) == 1:continueelif word == "诸葛亮" or word == "孔明曰":rword = "孔明"elif word == "关公" or word == "云长":rword = "关羽"elif word == "玄德" or word == "玄德曰":rword = "刘备"elif word == "孟德" or word == "丞相":rword = "曹操"else:rword = wordcounts[rword] = counts.get(rword, 0) + 1
for word in excludes:del(counts[word])
items = list(counts.items())
items.sort(key=lambda x:x[1], reverse=True)
for i in range(10):word, count=items[i]print (word, count)

excludes里面定义了一些出现次数较多但不是人名的词,这里主要语句就是 counts[rword] = counts.get(rword, 0) + 1 这一句字典类型的counts,如果word在counts中,返回word对应的值,否则返回0。后面用sort()函数和匿名函数lambda()进行排序,这里字典没有顺序,需要先转化为列表类型。输出结果如下:

3.导出数据文件


fo = open("三国人物出场次数.txt", "a")
for i in range(10):word, count=items[i]word = str(word)count = str(count)fo.write(word)fo.write(' ')fo.write(count)fo.write('\n')print (word, count)
print(items)
fo.close()

这里我们将数据导入到 三国人物出场次数.txt 这个文件里面。
4.将数据画出气泡图

总结

由此可知“曹操“,“ 孔明””刘备”是出场最多的人,这些只是简单的数据分析,作为此系列博客的开头篇,随着学习希望自己能实现完整用python分析四大名著。

用python分析四大名著(一)相关推荐

  1. 三国演义python分析系统_用python分析四大名著之三国演义

    点击上方"程序人生",选择"置顶公众号" 第一时间关注程序猿(媛)身边的故事 项目起因及意义 起初在浏览知乎时看见一篇文章觉得很有意思(用 Python 分析& ...

  2. 用python分析四大名著之三国演义

    点击上方"程序人生",选择"置顶公众号" 第一时间关注程序猿(媛)身边的故事 项目起因及意义 起初在浏览知乎时看见一篇文章觉得很有意思(用 Python 分析& ...

  3. Python分析离散心率信号(下)

    Python分析离散心率信号(下) 如何使用动态阈值,信号过滤和离群值检测来改善峰值检测. 一些理论和背景 到目前为止,一直在研究如何分析心率信号并从中提取最广泛使用的时域和频域度量.但是,使用的信号 ...

  4. Python分析离散心率信号(中)

    Python分析离散心率信号(中) 一些理论和背景 心率信号不仅包含有关心脏的信息,还包含有关呼吸,短期血压调节,体温调节和荷尔蒙血压调节(长期)的信息.也(尽管不总是始终如一)与精神努力相关联,这并 ...

  5. Python分析离散心率信号(上)

    Python分析离散心率信号(上) 一些理论和背景 心率包含许多有关信息.如果拥有心率传感器和一些数据,那么当然可以购买分析包或尝试一些可用的开源产品,但是并非所有产品都可以满足需求.也是这种情况.那 ...

  6. 盛夏海边,用Python分析青岛哪些景点性价比高

    作者 | 志斌 来源 | 志斌的python笔记 头图 | 付费下载于 IC Photo 在经过几年的热潮之后,人工智能AI算法已经在各行各业广泛使用了.例如在工业制造中,利用人工智能监测仪器仪表.人 ...

  7. Python分析101位《创造营2020》小姐姐,谁才是你心中的颜值担当?

    来源 | CDA 数据分析师 责编 |  Carol Show me data,用数据说话. 今天我们聊一聊<创造营2020>各个小姐姐,点击下方视频,先睹为快: 最近可以追的综艺真是太多 ...

  8. 用Python分析《红楼梦》:见证了贾府的兴衰,你是否还能“笑道”世事无常

    没读过<红楼梦>也能知道前后四十回是不是一个作者写的?很久以前,数据侠黎晨,用机器学习的算法分析了<红楼梦>,认为后四十回和前八十回内容上有明显差距.不过,数据侠楼宇却不这么认 ...

  9. 用Python分析了十年电影票房,原来我错过了这么多好电影!

    "玩电影票房数据,我教你啊" 3月8日妇女节,我很期待的超级英雄电影<惊奇队长>上映了,票房表现很快过亿,但大众口碑却让人失望. 一个有趣且常见的现象是,隔壁获奖无数, ...

最新文章

  1. python 正则表达式过滤文本中的html标签 源代码解析
  2. 前端学习(3077):vue+element今日头条管理-分支的的使用
  3. memcache 防火墙策略
  4. 米斯特白帽培训讲义(v2)实战篇 迅雷 CMS
  5. 【转】横向扩展与纵向扩展
  6. 例2.11 FatMouse' Trade - 九度教程第21题(贪心算法)
  7. C语言程序输入一个三位数取个位十位百位
  8. 使用torch.nn.BatchNorm1d出现Tensor for argument #2 ‘weight‘ is on CPU, but expected it to on GPU错误
  9. 使用tesseract-ocr进行文字识别
  10. 交大家简单又好吃的蛋黄酥的做法
  11. 为啥将phpstudy打开,却访问不了rips
  12. 通信算法之六十:SC_FDE系统的物理层算法设计与工程实现
  13. VBA·编译错误:ByRef参数类型不符
  14. 修改android默认锁屏方式
  15. 【全局规划】人工势场法(APF)
  16. 已经有211大学发布计算机专业,研究生复试上机考试说明
  17. 智能风控平台核心之风控决策引擎(一)
  18. 【Java】据给出的英文短文,作如下统计
  19. Setting property ‘source‘ to ‘org.eclipse.jst.jee.server
  20. 中国石油大学(北京)《线性代数》在线考试答案

热门文章

  1. 健康菜谱微信小程序+项目前后台源码(JavaSSM+Mysql)
  2. 数论读书笔记——线性丢番图方程——解不定方程
  3. C1认证学习十(Ipv6)
  4. 基于spark的车辆分析
  5. 部落卫队 2281
  6. android 5.1拍照后图片镜像处理
  7. 【车辆计数】基于matlab GUI背景差分法道路行驶多车辆检测【含Matlab源码 1911期】
  8. POS接口与GE接口区别
  9. SybilFuse:Combining Local Attributes with Global Structure to Perform Robust Sybil Detect(论文笔记)
  10. 《渴望生活——梵高传》读后感