namedtuple
- 自定義元組
- 可以通過屬性訪問(增加功能)
- 不可以動態增加新元素,保留了元組不可變特性
代碼
from collections import namedtuple
Mytuple = namedtuple("Mytuple",["x","y"])
n = Mytuple(11,22)
n.z = 123
print(n.x)
print(n.y)
print(n.z) # 錯誤,不可動態增加新元素
n = Mytuple([1, 2, 3, 4], [123, 345])
print(n.x) # [1, 2, 3, 4]
print(n.y) # [123, 345]
n = Mytuple(*[1, 2]) # 用列表賦值
print(n.x) # 1
print(n.y) # 2
deque
- 因為list是線性存儲,數據量大的時候,插入和刪除效率很低
- deque是為了高效實現插入和刪除操作的雙向列表
代碼
from collections import deque
q = deque(['a','b','c'])
q.append('x') # 默認添加到列表最后一項
q.appendleft('y') # 添加到列表第一項
q.pop() # 默認刪除列表最后一個元素
q.popleft() # 刪除列表的第一個元素
defaultdict
- 使用字典時,如果引用的Key不存在,就會拋出 KeyError
- 如果希望key不存在時,返回一個默認值,就可以用 defaultdict
- 默認值是用一個函數返回的,這里用的匿名函數
- 除了增加了默認值,其他操作和普通字典一樣
代碼
from collections import defaultdict
Mydict = defaultdict(lambda: 'N/A')
print(Mydict["abc"]) # N/A
OrderedDict
- OrderedDict 的有序性是按照插入的順序,而不是KEY的順序
代碼
from collections import OrderedDict
d = dict([('a', 1), ('b', 2), ('c', 3)])
print(d) # {'a': 1, 'c': 3, 'b': 2}
od = OrderedDict([('a', 1), ('b', 2), ('c', 3)])
# OrderedDict的Key是有序的
OrderedDict([('a', 1), ('b', 2), ('c', 3)])
Counter
from collections import Counter
c = Counter()
for ch in 'programming':
c[ch] = c[ch] + 1
print(c)
--------------------------------
Counter({'g': 2, 'm': 2, 'r': 2, 'a': 1, 'i': 1, 'o': 1, 'n': 1, 'p': 1})