Python中的collections模块

接下来主要对collections模块中的常用集合类进行介绍,调用collections模块:

from collections import *

1、defaultdict

        dict在使用时,当key值不存在时,直接添加value时会出现错误,使用defaultdict可以很好的规避该错误。defaultdict是对字典类型的补充,它可以给字典的值设置一个类型,当key不存在时可以自动生成相应类型的value。

如何使用defaultdict

        defaultdict接受一个工厂函数作为参数,如下来构造:

dict =defaultdict( factory_function)

         这个factory_function可以是list、set、str等等,作用是当key不存在时,返回的是工厂函数的默认值,比如list对应[ ],str对应的是空字符串,set对应set( ),int对应0,如下举例:

from collections import defaultdict

dict1 = defaultdict(int)
dict2 = defaultdict(set)
dict3 = defaultdict(str)
dict4 = defaultdict(list)
dict1[2] ='two'

print(dict1[1])
print(dict2[1])
print(dict3[1])
print(dict4[1])

输出:

0
set()

[]

举例:

from collections import defaultdict

test_data = (
    ('cat', 2),
    ('dog', 5),
    ('sheep', 3),
    ('cat', 1),
    ('sheep', 2)
)

test_data_dict = defaultdict(list)

for name, num in test_data:
    test_data_dict[name].append(num)
    
print (test_data_dict)

输出

defaultdict(<class 'list'>, {'cat': [2, 1], 'dog': [5], 'sheep': [3, 2]})

2、orderedDict

         在Python3.6之前的字典是无序的,但是有时候我们需要保持字典的有序性,orderDict可以在dict的基础上实现字典的有序性,这里的有序指的是按照字典key插入的顺序来排列,这样就实现了一个先进先出的dict,当容量超出限制时,先删除最早添加的key。

Python 的基础数据类型中的字典类型分为:无序字典 与 有序字典 两种类型

1.无序字典(普通字典):

输出:

可以看见,遍历一个普通字典,返回的数据和定义字典时的字段顺序是不一致的。

2.有序字典

输出:

有序字典可以按字典中元素的插入顺序来输出。

注意:

        有序字典的作用只是记住元素插入顺序并按顺序输出。如果有序字典中的元素一开始就定义好了,后面没有插入元素这一动作,那么遍历有序字典,其输出结果仍然是无序的,因为缺少了有序插入这一条件,所以此时有序字典就失去了作用,所以有序字典一般用于动态添加并需要按添加顺序输出的时候。

如下面这个列子:

输出:

发现输出还是无序的,因为在定义有序字典的同时也定义了初始值,没有存在按序添加的操作,所以有序字典是没有记录插入字段的顺序,最后遍历时,得到数据的顺序仍然是无序的。

3、deque

Python中的list是基于数组实现的,所以,查找容易,但是插入和删除操作时间复杂度较大。
deque就是为了高效实现插入和删除操作的双向列表,适合用于队列和栈,而且线程安全。
list只提供了append和pop方法来从list的尾部插入或者删除元素,deque新增了appendleft/popleft等方法可以更高效的在元素的开头来插入/删除元素。
举例:

from collections import deque
d = deque([1,2,3,4,5])
d.extendleft([0])
print d
d.extend([6,7])
d.popleft()
print (d)

可以进行双向操作元素,十分方便。

4、Counter

字典子类,为可以哈希的对象计数。
举例:

from collections import Counter

test_counter_data = ['cat', 'dog', 'sheep', 'cat', 'dog']
counter_data = Counter()

for item in test_counter_data:
    counter_data[item] += 1
    
print(counter_data)
输出:
Counter({'cat': 2, 'dog': 2, 'sheep': 1})

可以实现对一个对象中的元素进行计数。

5、namedtuple

先看一下官方文档中的相关片段:

collections.namedtuple(typenamefield_names*rename=Falsedefaults=Nonemodule=None)

Returns a new tuple subclass named typename. The new subclass is used to create tuple-like objects that have fields accessible by attribute lookup as well as being indexable and iterable. Instances of the subclass also have a helpful docstring (with typename and field_names) and a helpful __repr__() method which lists the tuple contents in a name=value format.

The field_names are a sequence of strings such as ['x', 'y']. Alternatively, field_names can be a single string with each fieldname separated by whitespace and/or commas, for example 'x y' or 'x, y'.

官方例子:

>>> # Basic example
>>> Point = namedtuple('Point', ['x', 'y'])
>>> p = Point(11, y=22)     # instantiate with positional or keyword arguments
>>> p[0] + p[1]             # indexable like the plain tuple (11, 22)
33
>>> x, y = p                # unpack like a regular tuple
>>> x, y
(11, 22)
>>> p.x + p.y               # fields also accessible by name
33
>>> p                       # readable __repr__ with a name=value style
Point(x=11, y=22

namedtuple是一个元组子类。
我们知道,Python中元组的一个重要特征就是元素不可增删改,而查找tuple元素时一般采取索引。
使用namedtuple(typename, field_name)可以命名tuple中的元素,之后便可使用名字来查找tuple中的值,有点类似于字典中的查找。
举例:

from collections import namedtuple
animal = namedtuple('animal', 'type age')
mark = animal(type='dog', age=2)
print (mark.type)
输出:
dog

使用namedtuple可以提高代码的可读性和文档性。

参考链接:

https://www.cnblogs.com/ybjourney/p/9020983.html

https://docs.python.org/3/library/collections.html#collections.namedtuple

https://www.jianshu.com/p/bbd258f99fd3

https://cloud.tencent.com/developer/news/492306

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: collections模块Python标准库的一个模块,提供了许多有用的数据类型。其包括: - deque: 双端队列 - Counter: 计数器 - OrderedDict: 有序字典 - defaultdict: 默认字典 - namedtuple: 命名元组 - ChainMap: 链接多个字典 使用这些类型可以更方便地进行数据操作和处理。 ### 回答2: collectionsPython标准库的一个模块,提供了许多有用的容器数据类型。这些数据类型是基于内置的数据类型(如字典,列表和集合等)的实现,以提供更多的功能和灵活性。 collections模块最常用的数据类型是:Counter、defaultdict、OrderedDict和namedtuple。 Counter是一个字典的子类,用于计算可哈希对象的出现次数。它可以接受任何可哈希对象的序列作为输入,并返回一个字典,其包含每个对象作为键和其出现次数作为值。 defaultdict是一个字典的子类,它可以接受一个工厂函数作为参数。当访问不存在的键时,默认会返回该工厂函数的返回值,而不是抛出KeyError异常。这对于处理缺失键的情况非常有用。 OrderedDict是一个有序的字典,它以插入顺序来维护元素的顺序。与普通的字典不同,OrderedDict可以记住元素的添加顺序,从而实现按照插入顺序进行遍历。 namedtuple是一个工厂函数,用于创建具有命名字段的元组子类。它允许我们为元组的每个字段指定一个名称,从而增加了元组的可读性和代码的可维护性。 除了上述常用的数据类型外,collections模块还提供了其他一些有用的类,如deque(双端队列)、ChainMap(合并多个字典)、UserDict(方便地创建字典的一种方式)等。 总而言之,collections模块扩展了Python内置的容器数据类型,提供了更多方便、灵活和高效的数据结构,使我们在处理数据时更加方便和高效。它是每个Python程序员都应该熟悉和掌握的重要模块之一。 ### 回答3: collections模块Python标准库的一个模块,提供了一些常用的数据类型和工具,用于扩展内置的数据类型,提供方便的数据结构和算法。 collections模块最常用的数据类型是容器类型,包括:Counter、defaultdict、deque、OrderedDict和namedtuple。 1. Counter:用于计数元素出现的次数,并以字典的形式返回计数结果。它可以用于快速计数列表、字符串或任何可迭代对象的元素。 2. defaultdict:是内置字典类(dict)的一个子类,它通过传入一个默认值工厂函数,当键不存在时返回该默认值。这对于需要设置默认值的字典非常有用。 3. deque:双端队列,可以快速在两端进行插入和删除操作,比内置的list类型更高效。 4. OrderedDict:有序字典,它会根据元素的插入顺序保持顺序,与普通字典不同,遍历时返回的键值对按照插入顺序排列。 5. namedtuple:命名元组,是一个生成类的工厂函数,用于创建具有字段名称的元组。它可以通过字段名称访问元组的元素,提高了程序的可读性。 除了这些常用的数据类型,collections模块还提供了一些其他的工具函数,用于处理迭代器、排序和计数等操作。 总之,collections模块Python开发者提供了一些有用的数据类型和工具,可以简化常见的数据操作,提高开发效率。无论是在处理复杂数据结构还是简单计数,使用collections模块可以更方便地进行操作和处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值