Python内建模块collections实现特殊容器数据类型

 更新时间:2023年06月25日 08:49:06   作者:小小张说故事  
collections模块是Python的内建模块之一,它实现了特殊的容器数据类型,提供了Python内建的数据类型dict、list、set、和tuple的高效替代选择

一、namedtuple

namedtuple() 函数是一个工厂函数,它返回一个子类,这个子类继承自 tuple 类,并且拥有名字,这个名字就是你传给 namedtuple() 的第一个参数。这个子类的实例就像一个普通的元组,但是还提供了方便的属性访问。

namedtuple是一种定义小型和不可变的数据类的简单方法。

from collections import namedtuple
# 创建一个namedtuple类型User,并包含name和age两个属性。
User = namedtuple('User', ['name', 'age'])
# 创建一个User对象
user = User(name='user1', age=23)
print(user.name)  # 输出:user1
print(user.age)   # 输出:23

二、deque

deque(双向队列)是一种来自 collections 模块的容器,它提供了从左端和右端高效、快速地添加和删除元素的功能。

from collections import deque
# 创建一个deque
d = deque(['a', 'b', 'c'])
# 从右端添加元素
d.append('d')     # d现在是deque(['a', 'b', 'c', 'd'])
# 从左端添加元素
d.appendleft('e')  # d现在是deque(['e', 'a', 'b', 'c', 'd'])
# 从右端删除元素
d.pop()           # 返回 'd', d现在是deque(['e', 'a', 'b', 'c'])
# 从左端删除元素
d.popleft()        # 返回 'e', d现在是deque(['a', 'b', 'c'])

三、Counter

collections模块的Counter类是一个简单的计数器,例如,它可以用来统计字符的个数:

from collections import Counter
c = Counter('hello world')  # 从一个可迭代对象创建
print(c)  # 输出 Counter({'l': 3, 'o': 2, 'h': 1, 'e': 1, ' ': 1, 'w': 1, 'r': 1, 'd': 1})

Counter对象有一个有用的方法most_common(n),该方法返回计数最多的n个元素的列表,每个元素是一个元组,元组的第一个元素是元素本身,第二个元素是元素的计数。

四、defaultdict

defaultdict是dict的一个子类,它接受一个工厂函数作为默认值,当查找的键不存在时,可以实例化一个值作为默认值。

from collections import defaultdict
# 使用列表(list)作为default_factory,当键不存在时,返回一个空列表。
dd = defaultdict(list)
# 添加一个键值对
dd['dogs'].append('Rufus')
dd['dogs'].append('Kathrin')
dd['dogs'].append('Mr Sniffles')
print(dd['dogs'])  # 输出: ['Rufus', 'Kathrin', 'Mr Sniffles']

五、OrderedDict

OrderedDict是dict的一个子类,它记住了元素插入的顺序。在Python 3.7之前,普通的dict并不保证键值对的顺序,而OrderedDict则按照插入的顺序排列元素。

从Python 3.7开始,dict也会保持插入顺序,但是OrderedDict仍然有它的特性,如重新排列字典的顺序等。

from collections import OrderedDict
d = OrderedDict()
d['first'] = 1
d['second'] = 2
d['third'] = 3
d['last'] = 4
# 输出 "first 1", "second 2", "third 3", "last 4"
for key in d:
    print(key, d[key])

六、结论

collections模块中还包含有其他有用的工具,如ChainMapUserDictUserList等等,这些都是非常实用的集合类。使用和理解这些数据结构可以让我们在编程中更加得心应手,代码更加高效和清晰。

上述这些是 collections 模块中最常用的一些数据结构,理解和熟练使用这些工具,可以极大提高我们编程的效率。希望这篇文章能帮助你深入理解Python中的collections模块,能够更好的使用Python进行编程。

以上就是Python内建模块collections实现特殊容器数据类型的详细内容,更多关于Python collections模块的资料请关注脚本之家其它相关文章!

相关文章

  • 浅析Python四种数据类型

    浅析Python四种数据类型

    在这篇文章里,我们给大家分享了关于Python的四种数据类型相关知识点内容,有兴趣的朋友们参考下。
    2018-09-09
  • python scatter函数用法实例详解

    python scatter函数用法实例详解

    这篇文章主要介绍了python scatter函数用法实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-02-02
  • Python PO设计模式的具体使用

    Python PO设计模式的具体使用

    这篇文章主要介绍了Python PO设计模式的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-08-08
  • Python集合set()使用的方法详解

    Python集合set()使用的方法详解

    这篇文章主要为大家详细介绍了Python集合set()使用的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-03-03
  • Python实现自动化设置Excel工作表行高和列宽

    Python实现自动化设置Excel工作表行高和列宽

    在数据处理和报表生成的日常工作中,我们常常需要与Excel文件打交道,本文将深入探讨如何利用Python实现Excel工作表行高和列宽的自动化设置,希望对大家有所帮助
    2025-09-09
  • python实现自动登录后台管理系统

    python实现自动登录后台管理系统

    这篇文章主要为大家详细介绍了python实现自动登录后台管理系统,并进行后续操作,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-10-10
  • PySpark和RDD对象最新详解

    PySpark和RDD对象最新详解

    Spark是一款分布式的计算框架,用于调度成百上千的服务器集群,计算TB、PB乃至EB级别的海量数据,PySpark是由Spark官方开发的Python语言第三方库,本文重点介绍PySpark和RDD对象,感兴趣的朋友一起看看吧
    2023-01-01
  • PyTorch CNN实战之MNIST手写数字识别示例

    PyTorch CNN实战之MNIST手写数字识别示例

    本篇文章主要介绍了PyTorch CNN实战之MNIST手写数字识别示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-05-05
  • Python实现银行账户资金交易管理系统

    Python实现银行账户资金交易管理系统

    这篇文章主要介绍了Python银行账户资金交易管理系统,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-01-01
  • pytorch VGG11识别cifar10数据集(训练+预测单张输入图片操作)

    pytorch VGG11识别cifar10数据集(训练+预测单张输入图片操作)

    这篇文章主要介绍了pytorch VGG11识别cifar10数据集(训练+预测单张输入图片操作),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-06-06

最新评论