python collections deque

collections是python的高级容器类库,包含了dict、truple之外的常用容器。

下面介绍常用的deque

1. deque是双端队列,可以从两端塞元素进去,也可以从两端取元素。

2. deque是线程安全的,可以用来做多线程的共享资源,我也是因为这个开始接触duque的

>>> from collections import deque
>>> a = [1, 2, 3, 4]
用列表初始化deque
>>> deq = deque(a)
>>> deq
deque([1, 2, 3, 4])
往deque中迭代入队列表原始
>>> deq.extend(a)
>>> deq
deque([1, 2, 3, 4, 1, 2, 3, 4])
从右端入队元素
>>> deq.append(5)
>>> deq
deque([1, 2, 3, 4, 1, 2, 3, 4, 5])
从左端输入元素
>>> deq.appendleft(6)
>>> deq
deque([6, 1, 2, 3, 4, 1, 2, 3, 4, 5])
从右端出队
>>> deq.pop()
5
从左端出队
>>> deq.popleft()
6
>>> deq
deque([1, 2, 3, 4, 1, 2, 3, 4])
从左往右旋转
>>> deq.rotate(-2)
>>> deq
deque([3, 4, 1, 2, 3, 4, 1, 2])
从右往左旋转
>>> deq.rotate(2)
>>> deq
deque([1, 2, 3, 4, 1, 2, 3, 4])
从文件输出到deque
比如,输入文件的倒数3行,得到大小为3的队列
>>> a = deque(open(‘test.txt‘), 3)
>>> a
deque([‘5\n‘, ‘6\n‘, ‘7\n‘], maxlen=3)
时间: 2024-10-16 23:03:07

python collections deque的相关文章

python之保留有限的历史记录(collections.deque)

1.deque(maxlen=N)创建一个固定长度的队列,当有新的记录加入而队列已经满时,会自动移除老的记录. from collections import deque q = deque(maxlen=3) q.append(1) q.append(2) q.append(3) q deque([1, 2, 3], maxlen=3) q.append(4) q deque([2, 3, 4], maxlen=3) 应用功能: 保存有限的历史记录collections.deque的完美应用场

python collections 模块

collections 模块里有一些比较好用的类型,是一些基础类型的扩展,是必要会的模块之一 Counter (计数器) 可以追踪值出现的次数,且是由大到小排列出来 >>> import collections >>> c1 = collections.Counter('adadwefffcvcc') >>> c1 Counter({'c': 3, 'f': 3, 'a': 2, 'd': 2, 'e': 1, 'w': 1, 'v': 1}) 2.O

Python collections模块总结

Python collections模块总结 除了我们使用的那些基础的数据结构,还有包括其它的一些模块提供的数据结构,有时甚至比基础的数据结构还要好用. collections ChainMap 这是一个为多个映射创建单一视图的类字典类型,也就是说,它同样具有字典类型的方法,它比基础数据结构中的字典的创建和多次更新要快,需要注意的是,增删改的操作都只会针对该对象的第一个字典,其余字典不会发生改变,但是如果是查找,则会在多个字典中查找,直到找到第一个出现的key为止. 特有方法 解释 maps 返

python的deque(双向)队列详解

首先 python的队列有很多种 Python标准库中包含了四种队列,分别是queue.Queue / asyncio.Queue / multiprocessing.Queue / collections.deque 可见deque是标准库collections中的 这其中最好用的是deque 以下是deque的基本操作: 它的操作很像list 同时 相比于list实现的队列,deque实现拥有更低的时间和空间复杂度.list实现在出队(pop)和插入(insert)时的空间复杂度大约为O(n

Python collections.defaultdict

Python collections.defaultdict 笔记 其实defaultdict 就是一个字典,只不过python自动的为它的键赋了一个初始值.这也就是说,你不显示的为字典的键赋初值python不会报错,看下实际例子. 比如你想计算频率 frequencies = {} for word in wordlist: frequencies[word] += 1 python会抛出一个KeyError 异常,因为字典索引之前必须初始化,可以用下面的方法解决 for word in wo

Python,collections模块

对collections相关方法进行学习和测试: # coding=utf-8 """ testCollections.py 对collections集合模块进行实践和测试 """ import collections import unittest class TestCollections(unittest.TestCase): def test_namedtuple(self): """ namedtuple是

Python collections系列之双向队列

双向队列(deque) 一个线程安全的双向队列 1.创建一个双向队列 import collections d = collections.deque() d.append('1') d.appendleft('10') d.appendleft('a') d.appendleft('1') 2.查看双向队列 print(d) 输出结果: deque(['1', 'a', '10', '1']) 3.查看双向队列的方法 >>> dir(d) ['__class__', '__copy__

Python collections类

c = Counter('abcdeabcdabcaba') import collectionsc = collections.Counter('abcdeabcdabcaba')print (c) 结果:Counter({'a': 5, 'b': 4, 'c': 3, 'd': 2, 'e': 1})结论:统计字符串出现的次数 import collectionsc = collections.Counter('abcdeabcdabcaba')print (c) ret = c.most_

collections.deque

d = collections.deque([])  # 创建双端队列d.append('a') # 在最右边添加一个元素,此时 d=deque('a')d.appendleft('b') # 在最左边添加一个元素,此时 d=deque(['b', 'a'])d.extend(['c','d']) # 在最右边添加所有元素,此时 d=deque(['b', 'a', 'c', 'd']) 原文地址:https://www.cnblogs.com/pjishu/p/10545734.html