Python标准库——collections模块的Counter类简介

1.collections模块

collections模块自Python 2.4版本开始被引入,包含了dict、set、list、tuple以外的一些特殊的容器类型,分别是:

  • OrderedDict类:排序字典,是字典的子类。引入自2.7。
  • namedtuple()函数:命名元组,是一个工厂函数。引入自2.6。
  • Counter类:为hashable对象计数,是字典的子类。引入自2.7。
  • deque:双向队列。引入自2.4。
  • defaultdict:使用工厂函数创建字典,使不用考虑缺失的字典键。引入自2.5。

文档参见:http://docs.python.org/2/library/collections.html

2.Counter类

Counter类的目的是用来跟踪值出现的次数。它是一个无序的容器类型,以字典的键值对形式存储,其中元素作为key,其计数作为value。计数值可以是任意的Interger(包括0和负数)。Counter类和其他语言的bags或multisets很相似。

2.1 创建

下面的代码说明了Counter类创建的四种方法:

Counter类的创建

>>>  c  =  Counter()  # 创建一个空的Counter类

>>>  c  =  Counter('gallahad')  # 从一个可iterable对象(list、tuple、dict、字符串等)创建

>>>  c  =  Counter({'a':  4,  'b':  2})  # 从一个字典对象创建

>>>  c  =  Counter(a=4,  b=2)  # 从一组键值对创建

2.2 计数值的访问与缺失的键

当所访问的键不存在时,返回0,而不是KeyError;否则返回它的计数。

计数值的访问

>>>  c  =  Counter("abcdefgab")
>>>  c["a"]
2
>>>  c["c"]
1
>>>  c["h"]
0

2.3 计数器的更新(update和subtract)

可以使用一个iterable对象或者另一个Counter对象来更新键值。

计数器的更新包括增加和减少两种。其中,增加使用update()方法:

计数器的更新(update)

>>>  c  =  Counter('which')
>>>  c.update('witch')  # 使用另一个iterable对象更新
>>>  c['h']
3
>>>  d  =  Counter('watch')
>>>  c.update(d)  # 使用另一个Counter对象更新
>>>  c['h']
4

减少则使用subtract()方法:

计数器的更新(subtract)

>>>  c  =  Counter('which')
>>>  c.subtract('witch')  # 使用另一个iterable对象更新
>>>  c['h']
1
>>>  d  =  Counter('watch')
>>>  c.subtract(d)  # 使用另一个Counter对象更新
>>>  c['a']
-1

2.4 键的删除

当计数值为0时,并不意味着元素被删除,删除元素应当使用del

键的删除

>>>  c  =  Counter("abcdcba")
>>>  c
Counter({'a':  2,  'c':  2,  'b':  2,  'd':  1})
>>>  c["b"]  =  0
>>>  c
Counter({'a':  2,  'c':  2,  'd':  1,  'b':  0})
>>>  del  c["a"]
>>>  c
Counter({'c':  2,  'b':  2,  'd':  1})

2.5 elements()

返回一个迭代器。元素被重复了多少次,在该迭代器中就包含多少个该元素。元素排列无确定顺序,个数小于1的元素不被包含。

elements()方法

>>>  c  =  Counter(a=4,  b=2,  c=0,  d=-2)
>>>  list(c.elements())
['a',  'a',  'a',  'a',  'b',  'b']

2.6 most_common([n])

返回一个TopN列表。如果n没有被指定,则返回所有元素。当多个元素计数值相同时,排列是无确定顺序的。

most_common()方法

>>>  c  =  Counter('abracadabra')
>>>  c.most_common()
[('a',  5),  ('r',  2),  ('b',  2),  ('c',  1),  ('d',  1)]
>>>  c.most_common(3)
[('a',  5),  ('r',  2),  ('b',  2)]

2.7 fromkeys

未实现的类方法。

2.8 浅拷贝copy

浅拷贝copy

>>>  c  =  Counter("abcdcba")
>>>  c
Counter({'a':  2,  'c':  2,  'b':  2,  'd':  1})
>>>  d  =  c.copy()
>>>  d
Counter({'a':  2,  'c':  2,  'b':  2,  'd':  1})

2.9 算术和集合操作

+、-、&、|操作也可以用于Counter。其中&和|操作分别返回两个Counter对象各元素的最小值和最大值。需要注意的是,得到的Counter对象将删除小于1的元素。

Counter对象的算术和集合操作

>>>  c  =  Counter(a=3,  b=1)
>>>  d  =  Counter(a=1,  b=2)
>>>  c  +  d  # c[x] + d[x]
Counter({'a':  4,  'b':  3})
>>>  c  -  d  # subtract(只保留正数计数的元素)
Counter({'a':  2})
>>>  c  &  d  # 交集:  min(c[x], d[x])
Counter({'a':  1,  'b':  1})
>>>  c  |  d  # 并集:  max(c[x], d[x])
Counter({'a':  3,  'b':  2})

3.常用操作

下面是一些Counter类的常用操作,来源于Python官方文档

Counter类常用操作

sum(c.values())  # 所有计数的总数

c.clear()  # 重置Counter对象,注意不是删除

list(c)  # 将c中的键转为列表

set(c)  # 将c中的键转为set

dict(c)  # 将c中的键值对转为字典

c.items()  # 转为(elem, cnt)格式的列表

Counter(dict(list_of_pairs))  # 从(elem, cnt)格式的列表转换为Counter类对象

c.most_common()[:-n:-1]  # 取出计数最少的n-1个元素

c  +=  Counter()  # 移除0和负值
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容

  • 一、Python简介和环境搭建以及pip的安装 4课时实验课主要内容 【Python简介】: Python 是一个...
    _小老虎_阅读 5,739评论 0 10
  • 基础语法 运行 Python 交互式解释器 在命令行窗口执行python后,进入 Python 的交互式解释器。 ...
    小天真_5eeb阅读 1,402评论 0 36
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,649评论 18 139
  • 1 对着电脑,把找工作的网页打开,开始投简历,边投边愤恨,竟沦落至此!小罗和我说,他每天的工作就是,把网站上新发布...
    陈清伟阅读 249评论 0 0
  • 我的成长经历是一个痛苦而又忧伤的过程。而最痛苦的时光几乎都是发生在我在外求学的日子里。 1、校园暴力事件 初一时,...
    壹人留阅读 728评论 2 2