30天拿下Python之collections模块

简介: 30天拿下Python之collections模块

概述

在上一节,我们介绍了Python的sqlite3模块,包括:sqlite3模块中一些常用的函数和类。在这一节,我们将介绍Python的collections模块。collections模块是Python中的内置模块,它实现了特殊的容器数据类型,提供了Python的通用内建容器的替代选择。

使用collections模块中的这些数据结构,可以帮助我们更有效地解决问题,并写出更简洁、更易于理解的代码。比如:如果我们需要一个字典,当尝试获取一个不存在的键时,返回一个默认值,而不是抛出一个异常,那么可以使用defaultdict。又比如:如果我们需要一个记住元素插入顺序的字典,那么可以使用OrderedDict。

下面,我们将逐一介绍collections模块中一些常用的函数和类。

collections.Counter类

collections.Counter类是一个字典子类,用于计数可哈希的对象。它返回一个字典,对应的键是输入值,值是输入值出现的次数。这是一个非常有用的工具,可以快速计数元素的数量。

from collections import Counter
result = Counter('hello')
# 输出:Counter({'l': 2, 'h': 1, 'e': 1, 'o': 1})
print(result)

在上面的示例代码中,向Counter类的构造函数传入了字符串。返回的result为一个字典,包含了每个字符及其出现的次数。当然,Counter也可以接受列表、元组、集合或任何其他可迭代对象作为参数。

collections.deque类

collections.deque类是一个双端队列,允许从队列的两端进行添加和弹出操作。双端队列是一种具有两个端点的队列,可以在队列的两端添加和弹出元素。deque支持线程安全、内存高效地添加(append)和弹出(pop),从两端都可以操作,具有GIL锁的线程安全。

from collections import deque
# 创建一个空的deque
d = deque()
# 在deque的右侧添加元素
d.append('h')
d.append('e')
d.append('l')
d.append('l')
d.append('o')
# 在deque的左侧添加元素
d.appendleft('C')
d.appendleft('S')
d.appendleft('D')
d.appendleft('N')
# 弹出deque右侧的元素
element = d.pop()
# 输出:'o'
print(element)
# 弹出deque左侧的元素
element = d.popleft()
# 输出:'N'  
print(element)


collections.defaultdict类

collections.defaultdict类是一个字典子类,用于创建一个类似于字典的数据结构。它覆盖了字典的getitem方法,以便当请求的键不存在时,可以返回一个默认值,而不是抛出KeyError异常。默认值是在创建defaultdict对象时通过参数指定的,如果默认值是一个工厂函数,则该函数将被调用以生成默认值。

from collections import defaultdict
# 创建一个defaultdict,默认值为0
dd = defaultdict(int)
# 添加几个键值对
dd['C'] = 66
dd['S'] = 99
# 访问一个不存在的键,返回默认值0
print(dd['D'])

collections.namedtuple函数

collections.namedtuple函数用于创建一个可以使用名字来访问元素内容的tuple子类。namedtuple非常有用,特别是当我们需要创建一些具有多个字段的数据结构时。相比使用字典或列表,namedtuple更加轻量级,并且可以直接通过属性名访问元素,而不需要使用索引。这就避免了在代码中使用数字索引来访问元组或列表的元素,提高了代码的可读性和可维护性。

from collections import namedtuple
# 创建一个namedtuple类,名为Point,具有xpos和ypos两个字段
Point = namedtuple('Point', ['xpos', 'ypos'])
# 创建一个Point对象
point = Point(66, 99)
# 访问对象的字段
# 输出:66
print(point.xpos)
# 输出:99
print(point.ypos)

collections.OrderedDict类

collections.OrderedDict类用于创建一个有序的字典对象。它继承自dict类,并添加了一些额外的功能,以保持字典中元素的插入顺序。OrderedDict与普通的dict类似,但它会记住元素被插入的顺序。当遍历OrderedDict时,元素将按照它们被插入的顺序返回。使用OrderedDict可以确保字典中的元素按照一定的顺序进行遍历,而不需要额外的排序操作。

from collections import OrderedDict
# 创建OrderedDict对象
od = OrderedDict()
# 添加元素
od['C'] = 66
od['S'] = 77
od['D'] = 88
od['N'] = 99
# 遍历OrderedDict
for key, value in od.items():
    print(key, value)

collections.UserList类

collections.UserList类是list的子类,允许用户自定义列表的行为。UserList提供了与list相同的接口,但允许用户覆盖或添加方法以修改其行为。UserList非常有用,特别是当你需要定制列表的行为,或需要添加额外的功能时。你可以通过继承UserList类,并重写其方法来实现自定义的列表功能。

from collections import UserList
class MyList(UserList):
    def __init__(self, list_init = None):
        super().__init__(list_init)
    def append(self, value):
        print(f"item {value} inserted")
        super().append(value)
 
# 创建一个MyList对象
my_list = MyList([66, 77, 88])
# 在列表中添加元素,输出:item 100 inserted  
my_list.append(100)
 
# 访问列表中的元素,输出:66
print(my_list[0])


使用UserList可以轻松地扩展列表的功能,并根据需要自定义其行为,这使得UserList成为处理特殊需求的列表操作的强大工具。除了自定义列表UserList,Python还内置了UserDict、UserSet、UserString,以允许用户定义他们自己的字典类、集合类和字符串类,这里就不再赘述了。


相关文章
|
12天前
|
弹性计算 人工智能 架构师
阿里云携手Altair共拓云上工业仿真新机遇
2024年9月12日,「2024 Altair 技术大会杭州站」成功召开,阿里云弹性计算产品运营与生态负责人何川,与Altair中国技术总监赵阳在会上联合发布了最新的“云上CAE一体机”。
阿里云携手Altair共拓云上工业仿真新机遇
|
8天前
|
机器学习/深度学习 算法 大数据
【BetterBench博士】2024 “华为杯”第二十一届中国研究生数学建模竞赛 选题分析
2024“华为杯”数学建模竞赛,对ABCDEF每个题进行详细的分析,涵盖风电场功率优化、WLAN网络吞吐量、磁性元件损耗建模、地理环境问题、高速公路应急车道启用和X射线脉冲星建模等多领域问题,解析了问题类型、专业和技能的需要。
2522 18
【BetterBench博士】2024 “华为杯”第二十一届中国研究生数学建模竞赛 选题分析
|
8天前
|
机器学习/深度学习 算法 数据可视化
【BetterBench博士】2024年中国研究生数学建模竞赛 C题:数据驱动下磁性元件的磁芯损耗建模 问题分析、数学模型、python 代码
2024年中国研究生数学建模竞赛C题聚焦磁性元件磁芯损耗建模。题目背景介绍了电能变换技术的发展与应用,强调磁性元件在功率变换器中的重要性。磁芯损耗受多种因素影响,现有模型难以精确预测。题目要求通过数据分析建立高精度磁芯损耗模型。具体任务包括励磁波形分类、修正斯坦麦茨方程、分析影响因素、构建预测模型及优化设计条件。涉及数据预处理、特征提取、机器学习及优化算法等技术。适合电气、材料、计算机等多个专业学生参与。
1525 15
【BetterBench博士】2024年中国研究生数学建模竞赛 C题:数据驱动下磁性元件的磁芯损耗建模 问题分析、数学模型、python 代码
|
4天前
|
存储 关系型数据库 分布式数据库
GraphRAG:基于PolarDB+通义千问+LangChain的知识图谱+大模型最佳实践
本文介绍了如何使用PolarDB、通义千问和LangChain搭建GraphRAG系统,结合知识图谱和向量检索提升问答质量。通过实例展示了单独使用向量检索和图检索的局限性,并通过图+向量联合搜索增强了问答准确性。PolarDB支持AGE图引擎和pgvector插件,实现图数据和向量数据的统一存储与检索,提升了RAG系统的性能和效果。
|
10天前
|
编解码 JSON 自然语言处理
通义千问重磅开源Qwen2.5,性能超越Llama
击败Meta,阿里Qwen2.5再登全球开源大模型王座
596 14
|
1月前
|
运维 Cloud Native Devops
一线实战:运维人少,我们从 0 到 1 实践 DevOps 和云原生
上海经证科技有限公司为有效推进软件项目管理和开发工作,选择了阿里云云效作为 DevOps 解决方案。通过云效,实现了从 0 开始,到现在近百个微服务、数百条流水线与应用交付的全面覆盖,有效支撑了敏捷开发流程。
19283 30
|
10天前
|
人工智能 自动驾驶 机器人
吴泳铭:AI最大的想象力不在手机屏幕,而是改变物理世界
过去22个月,AI发展速度超过任何历史时期,但我们依然还处于AGI变革的早期。生成式AI最大的想象力,绝不是在手机屏幕上做一两个新的超级app,而是接管数字世界,改变物理世界。
498 49
吴泳铭:AI最大的想象力不在手机屏幕,而是改变物理世界
|
1月前
|
人工智能 自然语言处理 搜索推荐
阿里云Elasticsearch AI搜索实践
本文介绍了阿里云 Elasticsearch 在AI 搜索方面的技术实践与探索。
18842 20
|
1月前
|
Rust Apache 对象存储
Apache Paimon V0.9最新进展
Apache Paimon V0.9 版本即将发布,此版本带来了多项新特性并解决了关键挑战。Paimon自2022年从Flink社区诞生以来迅速成长,已成为Apache顶级项目,并广泛应用于阿里集团内外的多家企业。
17530 13
Apache Paimon V0.9最新进展
|
3天前
|
云安全 存储 运维
叮咚!您有一份六大必做安全操作清单,请查收
云安全态势管理(CSPM)开启免费试用
368 4
叮咚!您有一份六大必做安全操作清单,请查收