Python基礎系列講解——內建庫之collections的使用

千鋒Python唐小強發表於2019-09-27

Python中有很多好用的內建的模組,比如datatime、json等等,本文介紹下collections模組的使用。使用collections模組時,首先要匯入模組,如下所示:

import collections

我們首先介紹下OrderedDict模組的使用。在Python3.5(含)中字典是無序的,即不會按照使用者插入的順序排序,如下所示,列印結果我們發現輸出並沒有按輸入的順序輸出。

x = dict() # 無序字典
x['stock1'] = "600213"
x['stock2'] = "600223"
x['stock3'] = "600233"
print(x) # {'stock1': '600213', 'stock3': '600233', 'stock2': '600223'}

使用operator.itemgetter對字典排序後,返回的是一個list變數,而不是字典,倘若再將這個list轉換為字典後,會發現又變回了無序字典。如下所示:

x = {"stock1": "600213", "stock2": "600223", "stock3": "600233"}
sorted_x = sorted(x.items(), key=operator.itemgetter(0))
print(type(x)) # <class 'dict'>
print(type(sorted_x)) # <class 'list'>
print(dict(sorted_x)) # {'stock1': '600213', 'stock3': '600233', 'stock2': '600223'}

如果要使字典保持我們插入的順序怎麼辦呢?可以用collections.OrderedDict來初始化字典,使無序字典成為有序字典,如下所示:

x = OrderedDict()
x['stock1'] = "600213"
x['stock2'] = "600223"
x['stock3'] = "600233"
print(x) # OrderedDict([('stock1', '600213'), ('stock2', '600223'), ('stock3', '600233')])
print(type(x)) # <class 'collections.OrderedDict'>

OrderedDict生成的字典支援如下屬性:

# values() 獲取字典所有的value,返回一個列表
print(x.values()) # odict_values(['600213', '600223', '600233'])
# setdefault() 獲取指定key的value,如果key不存在,則建立
val = x.setdefault('stock4')
print(val, x) # None OrderedDict([('stock1', '600213'), ('stock2', '600223'), ('stock3', '600233'), ('stock4', None)])
# popitem() 按照後進先出原則,刪除最後加入的元素,返回key-value
print(x.popitem(), x) # ('stock4', None) OrderedDict([('stock1', '600213'), ('stock2', '600223'), ('stock3', '600233')])
# pop() 獲取指定key的value,並在字典中刪除
k = x.pop('stock1')
print(k, x) # 600213 OrderedDict([('stock2', '600223'), ('stock3', '600233')])
# keys() 獲取字典所有的key
print(x.keys())
# clear() 清空有序字典
#x.clear()
# copy() 複製
new_dic = x.copy()
print(new_dic)
# items(返回由“鍵值對組成元素“的列表)
print(x.items())
# fromkeys() 指定一個列表,把列表中的值作為字典的key, 生成一個字典
dic = OrderedDict()
name = ['allen', 'belln', 'cllen']
print(dic.fromkeys(name)) # OrderedDict([('allen', None), ('belln', None), ('cllen', None)])
print(dic.fromkeys(name, 20)) # OrderedDict([('allen', 20), ('belln', 20), ('cllen', 20)])

從Python 3.6開始,Python的字典底層機制更改後已經變成為有序字典了。雖然collections.OrderedDict的使用價值降低了,不過collections中的defaultdict仍然很有用,它可以實現一鍵多值的字典,如下所示:

y = defaultdict(list) # 一鍵多值字典使用defaultdict
y["stock"].append("600213")
y["stock"].append("600223")
y["stock"].append("600413")
y["stock"].append("600513")
y["stock"].append("600225")
y["stock"].append("600273")
print(y) # defaultdict(<class 'list'>, {'stock': ['600213', '600223', '600413', '600513', '600225', '600273']})

接下來再介紹下collections中的Counter。Counter是一個簡單的計數器,目的是用來跟蹤值出現的次數。Counter以字典的鍵值對形式儲存值出現的次數,如下所示:

c_dict = Counter('yyydadyyyaadadsaaaxxxx')
print(c_dict) # Counter({'a': 7, 'y': 6, 'd': 4, 'x': 4, 's': 1})

當然也可以使用for迴圈實現跟蹤值出現的次數,如下所示,不過使用Counter更加高效。

data = 'yyydadyyyaadadsaaaxxxx'
val_cnt = {}
for i in data:
 i_cnt = val_cnt.get(i,0) # 查詢鍵的值
 val_cnt[i] = i_cnt + 1
print(val_cnt) # {'y': 6, 'd': 4, 'a': 7, 's': 1, 'x': 4}
print(val_cnt.get('a')) # 7

最後我們再介紹一下ChainMap,它可以加速字典的合併。通常我們合併字典的方式如下所示:

dicta = {i: i + 1 for i in range(1, 100, 2)}
dictb = {i: i + 2 for i in range(1, 100, 2)}
dictc = {i: i + 3 for i in range(1, 100, 2)}
dictd = {i: i + 4 for i in range(1, 100, 2)}
dic_total = dicta.copy()
dic_total.update(dictb)
dic_total.update(dictc)
dic_total.update(dictd)
print(dic_total)
print(dic_total.get(3, 0))

使用更高效的ChainMap方法,如下所示:

dic_total = ChainMap(dicta, dictb, dictc, dictd)


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69923331/viewspace-2658546/,如需轉載,請註明出處,否則將追究法律責任。

相關文章