前言
此系列文章将学习总结经常用到的几个collections的方法。
collections.deque
语法:collections.deque([iterable[, maxlen]])
使用方法:
我们给deque
传入一个可迭代对象iterable,返回一个新的deque对象,这个deque
对象包含iterable的所有元素。
那么这个deque
对象到底是个什么鬼?
其实它是一种类似于栈和队列的容器,它有如下优点:
deque
支持线程安全;- 在
deque
两端做append
和pop
操作的时间复杂度都为O(1); - 相对于列表来说
deque
能做更多的事,而且效率更高; - 在创建
deque
时我们可以通过参数maxlen来指定它长度,在deque
长度达到饱和时,如果继续向里面添加元素,那么相应的多余的元素会从添加元素相反的方向给删除掉。
deque
支持如下的方法来操作deque
里面的元素:
-
append(x)
:在deque
的右端添加元素x
。 -
appendleft(x)
:在deque
的左端添加元素x
。 -
clear()
:清空deque
里面的所有元素。 -
copy()
:创建一份deque
的浅拷贝。 -
count(x)
:在deque
中统计元素x
出现的次数。 -
extend(iterable)
:在deque
的右端将iterable
里面的所有元素依次添加进来。 -
extendleft(iterable)
:在deque
的左端将iterable
里面的所有元素依次添加进来。a = collections.deque([2, 3, 4, 1, 9, 8]) a.extendleft([1, 2, 3, 4, 5, 6]) print(a) # 输出结果为: deque([6, 5, 4, 3, 2, 1, 2, 3, 4, 1, 9, 8])
-
index(x[, start[, stop]])
:在deque
的指定索引范围内查找元素x
并返回第一个x
的索引,没有则会抛出ValueError
的异常。 -
insert(i, x)
:将元素x
插入到deque
中位置为i
的地方。如果在插入元素后deque
超出了最大长度则会抛出IndexError
的异常。# 例1: a = collections.deque([2, 3, 4, 1, 9, 8]) a.insert(3, 6) print(a) # 结果输出为: deque([2, 3, 4, 6, 1, 9, 8]) # 例2: a = collections.deque([2, 3, 4, 1, 9, 8], 6) a.insert(3, 6) # 结果输出为: IndexError: deque already at its maximum size
-
pop()
:删除并返回deque
中最右端的元素。如果deque
为空则会抛出IndexError
的异常。 -
popleft()
:删除并返回deque
中最左端的元素。如果deque
为空则会抛出IndexError
的异常。 -
remove(value)
:删除在deque
中找到的第一个元素value
,如果没有找到则会抛出ValueError
的异常。 -
reverse()
:原地翻转deque
,返回值为None
。 -
rotate(n=1)
:将deque
右边n
个元素进行旋转,如果n
为负数,则将deque
左边的n
个元素进行旋转。a = collections.deque([2, 3, 4, 1, 9, 8]) a.rotate(3) print(a) # 输出结果为: deque([1, 9, 8, 2, 3, 4])
总结
想要查看更多内容,请移步官方文档:
https://docs.python.org/3.6/library/collections.html