欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

怎么使用Python內(nèi)置庫(kù)collections-創(chuàng)新互聯(lián)

這篇文章主要講解了“怎么使用Python內(nèi)置庫(kù)collections”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“怎么使用Python內(nèi)置庫(kù)collections”吧!

成都創(chuàng)新互聯(lián)主要從事網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站制作、網(wǎng)頁(yè)設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)南開,十載網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):028-86922220

Python中有很多好用的內(nèi)置的模塊,比如datatime、json等等,本文介紹下collections模塊的使用。使用collections模塊時(shí),首先要導(dǎo)入模塊,如下所示:

import collections

我們首先介紹下OrderedDict模塊的使用。在Python3.5(含)中字典是無序的,即不會(huì)按照使用者插入的順序排序,如下所示,打印結(jié)果我們發(fā)現(xiàn)輸出并沒有按輸入的順序輸出。

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

使用operator.itemgetter對(duì)字典排序后,返回的是一個(gè)list變量,而不是字典,倘若再將這個(gè)list轉(zhuǎn)換為字典后,會(huì)發(fā)現(xiàn)又變回了無序字典。如下所示:

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,返回一個(gè)列表
print(x.values()) # odict_values(['600213', '600223', '600233'])
# setdefault() 獲取指定key的value,如果key不存在,則創(chuàng)建
val = x.setdefault('stock4')
print(val, x) # None OrderedDict([('stock1', '600213'), ('stock2', '600223'), ('stock3', '600233'), ('stock4', None)])
# popitem() 按照后進(jìn)先出原則,刪除最后加入的元素,返回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(返回由“鍵值對(duì)組成元素“的列表)
print(x.items())
# fromkeys() 指定一個(gè)列表,把列表中的值作為字典的key, 生成一個(gè)字典
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的字典底層機(jī)制更改后已經(jīng)變成為有序字典了。雖然collections.OrderedDict的使用價(jià)值降低了,不過collections中的defaultdict仍然很有用,它可以實(shí)現(xiàn)一鍵多值的字典,如下所示:

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是一個(gè)簡(jiǎn)單的計(jì)數(shù)器,目的是用來跟蹤值出現(xiàn)的次數(shù)。Counter以字典的鍵值對(duì)形式存儲(chǔ)值出現(xiàn)的次數(shù),如下所示:

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

當(dāng)然也可以使用for循環(huán)實(shí)現(xiàn)跟蹤值出現(xiàn)的次數(shù),如下所示,不過使用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

最后我們?cè)俳榻B一下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)

感謝各位的閱讀,以上就是“怎么使用Python內(nèi)置庫(kù)collections”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對(duì)怎么使用Python內(nèi)置庫(kù)collections這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

本文題目:怎么使用Python內(nèi)置庫(kù)collections-創(chuàng)新互聯(lián)
網(wǎng)頁(yè)鏈接:http://aaarwkj.com/article28/cocccp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供標(biāo)簽優(yōu)化、網(wǎng)站改版、網(wǎng)站收錄網(wǎng)站維護(hù)、App設(shè)計(jì)、網(wǎng)站內(nèi)鏈

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化
人妻少妇系列一区二区| 日本精品三级一区二区视频| 国产精品日本一区二区三区在线| 日本久久精品视频一区| 内射极品美女在线观看| 极品白嫩少妇无套内谢| 中文字幕一区二区久久综合| 国产黄a三级三级三级老师绑| 亚洲成人av福利网站| 粗长挺进新婚人妻诗岚| 欧美亚洲综合激情在线| 免费观看亚洲视频一区二区三区 | 午夜福利视频在线观看| 日本一区二区三区视频| 日产精品一级二级三级爱| 又黄又爽区一区二区三| 操老熟女一区二区三区| 草嫩av一区二区三区| 一区二区日韩欧美国产| 国产精品偷伦一区二区| 中文字幕九七精品乱码| 2021久久国产综合精品青草| 91亚洲熟妇国产熟妇肥婆| 人妖系列中文字幕欧美系列| 亚洲国产精品一区性色| 日韩天堂视频在线播放| 海外成人永久免费视频| 日韩在线欧美在线一区二区| 国产午夜视频成人无遮挡| 久久国产三级久久久久久| 午夜体内射精免费视频| 精品爆白浆一区二区三区| 日本熟熟妇丰满人妻啪啪| 日韩av一区三区在线| 黑丝美女大战白丝美女| 人妻少妇久久久久久69| 日本一道二区三区我不卡| 欧美一区二区三区亚洲| 日韩视频看看色网站| 欧洲亚洲国产一区二区| 国产三级精品久久三级国专区|