python collections模块示例详解
collections
模块是Python
标准库中的一个模块,提供了一些有用的数据结构,用于扩展内置的数据类型。
collections
模块包含以下几个重要的数据结构:
OrderedDict
:有序字典,以插入的顺序保存元素。可以按照添加的顺序遍历字典。defaultdict
:默认字典,当访问不存在的键时,会返回一个默认值,而不会抛出KeyError
异常。Counter
:计数器,用于统计可哈希对象的频率。可以快速计算一个序列中每个元素出现的次数。deque
:双端队列,可以在两端高效地添加和删除元素。比列表的操作更快,并且支持线程安全的操作。namedtuple
:命名元组,可以创建一个具有命名字段的元组类。可以通过字段名访问元组的元素,而不是使用索引。
这些数据结构在不同的场景下非常有用,可以提供更高效的数据操作和更方便的数据访问方式。可以根据具体需求选择合适的数据结构来提升代码的性能和可读性。
示例代码
Counter
(计数器)Counter
类是一个简单的计数器,可以用于统计可哈希对象的出现次数。
from collections import Counter words = ['apple', 'banana', 'apple', 'orange', 'banana', 'apple'] word_count = Counter(words) print(word_count) # 输出:Counter({'apple': 3, 'banana': 2, 'orange': 1}) print(word_count['apple']) # 输出:3 print(word_count['banana']) # 输出:2 print(word_count['grape']) # 输出:0
defaultdict
(默认字典)defaultdict
类是一个字典,它提供了一个默认值,当访问不存在的键时返回指定的默认值。
from collections import defaultdict fruit_dict = defaultdict(int) fruit_dict['apple'] += 1 fruit_dict['banana'] += 2 print(fruit_dict) # 输出:defaultdict(<class 'int'>, {'apple': 1, 'banana': 2}) print(fruit_dict['apple']) # 输出:1 print(fruit_dict['orange']) # 输出:0(int类型的默认值)
deque
(双端队列)deque
类是一个双端队列,支持从队列的两端进行操作。
from collections import deque queue = deque(['apple', 'banana', 'orange']) queue.append('grape') # 在队列末尾添加元素 queue.appendleft('melon') # 在队列头部添加元素 print(queue) # 输出:deque(['melon', 'apple', 'banana', 'orange', 'grape']) queue.pop() # 移除队列末尾的元素 queue.popleft() # 移除队列头部的元素 print(queue) # 输出:deque(['apple', 'banana', 'orange'])
这只是collections
模块中的几个类和它们的示例,还有其他一些类和方法可以在需要时进一步探索和使用。
到此这篇关于python collections模块详解的文章就介绍到这了,更多相关python collections模块内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
python 爬取豆瓣电影短评并利用wordcloud生成词云图
这篇文章主要介绍了python 爬取豆瓣电影短评并利用wordcloud生成词云图,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下2022-06-06Pytorch nn.Unfold() 与 nn.Fold()图码详解(最新推荐)
这篇文章主要介绍了Pytorch nn.Unfold() 与 nn.Fold()图码详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-05-05
最新评论