实际案例
  • 某随机序列[12, 5, 6, 4, 6, 5, 5, 7, …]中,找到出现次数最高的3个元素,它们出现次数是多少?
  • 对某英文文章的单词,进行词频统计,找到出现次数最高的10个单词,它们出现次数是多少?

现在我们以序列为例,看下我们如何处理该问题。首先我们先创建一个序列,具体操作如下:

from random import randint# 创建随机数序列
data = [randint(0, 5) for _ in xrange(20)]

我们思考一下,最终的统计结果必定是字典类型的。因此,我们可在上述的代码中进行如下操作:

# -*- coding: utf-8 -*-from random import randint# 创建随机数序列
data = [randint(0, 5) for _ in xrange(20)]
print data# 创建字典,以data序列的值为字典的键,值初始化为0
c = dict.fromkeys(data, 0)
print c# 遍历data序列
for x in data:c[x] += 1print c

输出结果如下:

[5, 0, 1, 5, 2, 5, 0, 4, 1, 2, 4, 1, 4, 1, 0, 3, 4, 2, 0, 4]
{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0}
{0: 4, 1: 4, 2: 3, 3: 1, 4: 5, 5: 3}

这样,我们就统计出了序列中各个元素出现的次数。再回到实际案例中,案例1要求找到出现次数最高的3个元素。那我们就要根据字典的值,对字典的元素进行排序,具体操作如下:

# -*- coding: utf-8 -*-from random import randint# 创建随机数序列
data = [randint(0, 5) for _ in xrange(20)]
print data# 创建字典,以data序列的值为字典的键,值初始化为0
c = dict.fromkeys(data, 0)
print c# 遍历data序列
for x in data:c[x] += 1print c# 根据键值进行从大到小排序
c_list = sorted(c.items(), key=lambda i:i[1], reverse=True)# 打印出现次数最多的3个元素
print c_list[:3]

其输出结果如下:

[5, 0, 1, 5, 2, 5, 0, 4, 1, 2, 4, 1, 4, 1, 0, 3, 4, 2, 0, 4]
{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0}
{0: 4, 1: 4, 2: 3, 3: 1, 4: 5, 5: 3}
[(4, 5), (0, 4), (1, 4)]

除上述方法外,我们还可以使用collections.Counter对象处理该问题。首先,将序列传入Counter的构造器,得到Counter的对象是元素频度的字典;然后,我们利用Counter.most_common(n)方法得到频度最高的n个元素的列表;最后,我们输出频度最高的3个元素。collections.Counter的相关操作可具体参考Python官方文档,此处的代码具体如下所示:

# -*- coding: utf-8 -*-from random import randint
from collections import Counter# 创建随机数序列
data = [randint(0, 5) for _ in xrange(20)]
print data# 创建字典,以data序列的值为字典的键,值初始化为0
c = dict.fromkeys(data, 0)
print c# 遍历data序列
for x in data:c[x] += 1print c
# 统计元素的频率
counter = Counter(data)# 打印出现次数最多的3个元素
print counter.most_common(3)

其输出结果如下:

[5, 0, 1, 5, 2, 5, 0, 4, 1, 2, 4, 1, 4, 1, 0, 3, 4, 2, 0, 4]
{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0}
{0: 4, 1: 4, 2: 3, 3: 1, 4: 5, 5: 3}
[(4, 5), (0, 4), (1, 4)]

好了,实际案例中的第一个案例我们已经圆满解决了。现在,让我们看看实际案例中的第二个案例。第二个案例是要求我们对英文单词进行词频统计,这里我们就要采用正则表达式了。我们运用正则表达式把英文单词一个一个地分割出来,然后再使用collections.Counter对象进行词频统计,最后,我们输出出现次数最高的10个单词,其代码如下:

# -*- coding: utf-8 -*-import refrom collections import Counter# 读入test.txt文件
text = open("test.txt").read()# 运用正则表达式做切割
word_list = re.split("\W+", text)# 统计英文单词的词频
counter = Counter(word_list)# 打印出现次数最多的10个元素
print counter.most_common(10)

其中,输出结果如下:

[('in', 12), ('the', 11), ('as', 10), ('China', 9), ('by', 7), ('AI', 7), ('guideline', 6), ('and', 6), ('to', 5), ('intelligence', 5)]

代码中,test.txt文件的内容来自扇贝新闻。这样我们也圆满完成实际案例中的第二个案例。

简书个人主页:http://www.jianshu.com/u/766a46e00f6b

如何统计序列中元素的出现的频度相关推荐

  1. python中读取txt文件、统计其中所有字母出现的频度_Python编程小技巧:如何统计序列中元素的出现频度...

    原标题:Python编程小技巧:如何统计序列中元素的出现频度 实际案例 某随机序列中,找到出现次数最高的三个元素,他们的出现次数是多少? 对某英文文章的单词进行词频统计,找到出现次数最高的10个单词, ...

  2. python数据结构-如何统计序列中元素的频度

    如何统计序列中元素的频度 问题举例 如何找出随机序列[1, 5, 6, 5, 3, 2, 1, 0, 6, 1, 6]中出现频度最高的3个元素? 如何统计某篇英文文章中词频最高的5个单词? 将序列转换 ...

  3. 统计词语出现次数python_Python实战教程:如何统计序列中元素的出现频度

    实际操作中,我们该如何统计序列中元素的出现频度,这篇Python实战教程手把手教你! 实际案例 某随机序列中,找到出现次数最高的三个元素,他们的出现次数是多少? 对某英文文章的单词进行词频统计,找到出 ...

  4. 【Python教程】统计序列中元素出现频度的详细方法

    例1:从随机列表中,找到找到出现次数最高的3个元素,及出现次数 方法一: from random import randint date = [randint(0, 20) for _ in rang ...

  5. python学习--统计序列中元素出现的频度(次数)

    例如有一个列表 l=[1,1,-1,2,3,22,34,32,2,-3,34,22,-5] 统计列表中每个元素出现的多少次 方式一: 先把列表变成一个字典dict,字典的key对应列表中的每一个元素, ...

  6. Python小练习—— 如何统计序列中元素的频度

    案例: 1.某随机序列[12, 5, 6, 4,6, 5, 12, 7, 12, 4],找到次数最高的3个元素,它们出现的次数是多少 2.对某英文文章的单词,进行词频统计,找到出现次数最高的10个单词 ...

  7. python统计元素个数_python怎么统计列表中元素的个数

    python统计列表中元素的个数的方法:可以通过count()方法来实现.该方法可以统计字符串中某个字符出现的次数,并返回子字符串在字符串中出现的次数.具体用法如:[count=List.count( ...

  8. boost::spirit模块从不同序列中元素的解析输入填充单个融合序列

    boost::spirit模块从不同序列中元素的解析输入填充单个融合序列 实现功能 C++实现代码 实现功能 boost::spirit模块从不同序列中元素的解析输入填充单个融合序列 C++实现代码 ...

  9. boost::spirit模块实现使用单个融合序列来生成不同序列中元素的输出的测试程序

    boost::spirit模块实现使用单个融合序列来生成不同序列中元素的输出的测试程序 实现功能 C++实现代码 实现功能 boost::spirit模块实现使用单个融合序列来生成不同序列中元素的输出 ...

最新文章

  1. matlab bs2rv.m,Matlab智能算法之遗传算法(一)
  2. 项目管理中的组织计划
  3. ThinkPHP3.2 G函数代码及 使用方法
  4. 2018qs计算机科学专业,2018QS世界大学计算机科学专业排名.docx
  5. vue自定义组件是.vue还是html,Vue自定义组件的四种方式示例详解
  6. 微信H5页面嵌入百度地图---解决手机的webKit定位,ios系统对非https网站不提供支持问题
  7. Web开发之django(二Admin)
  8. 关于WordPress登录后跳转到指定页面
  9. 写给非网工的CCNA教程(7)通过VLAN连接实现同网段通信
  10. 基于大数据技术的全国高速公路通行数据 动态监测平台建设
  11. CCNA考试题库中英文翻译版及答案3
  12. python 报警声音的实现
  13. webservice 缺少根元素_草莓种植,这2种元素至关重要,直接影响草莓的产量和品质...
  14. Google回归中国,你准备好成为Googler了吗?
  15. 如何提高自己的分析能力
  16. 怎么用别的方法里的变量_微波炉烤鸡翅的方法 怎么用微波炉烤鸡翅
  17. PO:通过Floder限制订单汇总中采购单价及金额栏位
  18. C++学习路线图(重整理)
  19. Cookie命名的由来
  20. 智慧警务:如何利用视频智能分析技术助力城市警务可视化综合监管与指挥系统

热门文章

  1. windows PHP 5 版本的下载
  2. 2020年PMP笔记归纳第三章项目经理的角色
  3. python中pygame背景颜色为啥没生效_如何更改pygame中的背景图像?
  4. 怎么用鸿蒙os系统,鸿蒙OS2.0系统怎么降级到EMUI11 鸿蒙OS2.0系统降级到EMUI11方法...
  5. ZZULIOJ:1001植树问题
  6. PYNQ搭建系统-Petalinux上网方式
  7. 计算机维修主板电容谷包维修,计算机主板维修之电容篇
  8. Android GPRS上网过程中数据图标的变化过程
  9. 如何判断外汇平台是否整个?MT4外汇投资靠谱吗?
  10. 终于把python的所有库整理完毕了,现在一篇python库的字典诞生了