pythondict(zip())_python基础:zip和dict详解
一.zip函數(shù):接受任意多個(gè)(包括0個(gè)和1個(gè))序列作為參數(shù),返回一個(gè)tuple列表。
1.示例1:
x = [1, 2, 3]
y = [4, 5, 6]
z = [7, 8, 9]
xyz = zip(x, y, z)
print xyz
運(yùn)行的結(jié)果是:
[(1, 4, 7), (2, 5, 8), (3, 6, 9)]
從這個(gè)結(jié)果可以看出zip函數(shù)的基本運(yùn)作方式。
2.示例2:
x = [1, 2, 3]
y = [4, 5, 6, 7]
xy = zip(x, y)
print xy
運(yùn)行的結(jié)果是:
[(1, 4), (2, 5), (3, 6)]
從這個(gè)結(jié)果可以看出zip函數(shù)的長(zhǎng)度處理方式。
3.示例3:
x = [1, 2, 3]
x = zip(x)
print x
運(yùn)行的結(jié)果是:
[(1,), (2,), (3,)]
從這個(gè)結(jié)果可以看出zip函數(shù)在只有一個(gè)參數(shù)時(shí)運(yùn)作的方式。
4.示例4:
x = zip()
print x
運(yùn)行的結(jié)果是:
[]
從這個(gè)結(jié)果可以看出zip函數(shù)在沒(méi)有參數(shù)時(shí)運(yùn)作的方式。
5.示例5:
x = [1, 2, 3]
y = [4, 5, 6]
z = [7, 8, 9]
xyz = zip(x, y, z)
u = zip(*xyz)
print u
運(yùn)行的結(jié)果是:
[(1, 2, 3), (4, 5, 6), (7, 8, 9)]
一般認(rèn)為這是一個(gè)unzip的過(guò)程,它的運(yùn)行機(jī)制是這樣的:
在運(yùn)行zip(*xyz)之前,xyz的值是:[(1, 4, 7), (2, 5, 8), (3, 6, 9)]
那么,zip(*xyz) 等價(jià)于 zip((1, 4, 7), (2, 5, 8), (3, 6, 9))
所以,運(yùn)行結(jié)果是:[(1, 2, 3), (4, 5, 6), (7, 8, 9)]
注:在函數(shù)調(diào)用中使用*list/tuple的方式表示將list/tuple分開(kāi),作為位置參數(shù)傳遞給對(duì)應(yīng)函數(shù)(前提是對(duì)應(yīng)函數(shù)支持不定個(gè)數(shù)的位置參數(shù))
6.示例6:
x = [1, 2, 3]
r = zip(* [x] * 3)
print r
運(yùn)行的結(jié)果是:
[(1, 1, 1), (2, 2, 2), (3, 3, 3)]
它的運(yùn)行機(jī)制是這樣的:
[x]生成一個(gè)列表的列表,它只有一個(gè)元素x
[x] * 3生成一個(gè)列表的列表,它有3個(gè)元素,[x, x, x]
zip(* [x] * 3)的意思就明確了,zip(x, x, x)
二、dict操作
1、使用zip創(chuàng)建字典
key = 'abcde'
value = range(1, 6)
dict(zip(key, value))
2、使用items()來(lái)遍歷字典
for key,value in d.items():
3.使用get, pop來(lái)獲取/刪除key
首先,dict[key] 與 delete dict[key]也可以獲取/刪除key。但是key不存在時(shí),會(huì)引發(fā) KeyError 異常。為了避免引發(fā)異常可以使用帶defaut參數(shù)的get和pop函數(shù)
get(key[, default])
如果key在字典中,返回對(duì)應(yīng)的value, 否則返回default。所以從來(lái)不會(huì)引發(fā)異常。
pop(key[, default])
如果default未設(shè)置,則如果key不在字典中,刪除key將引發(fā)異常。使用時(shí)加上default。
4、dict(dict1, **dict2)合并兩個(gè)字典
合并兩個(gè)字典可以先把兩個(gè)字典分成key-value對(duì),再連接兩個(gè)key-value對(duì),生成新的字典。即 dict(dict1.items()+dict2.items()) ,不過(guò)效率有些低。
使用效率更高的 dict(dict1, **dict2) 連接兩個(gè)字典。如果dict1與dict2含有相同的key,那么dict2的value會(huì)覆蓋dict1
1 dict1 = {"a" : "apple", "b" : "banana"}2 print(dict1)3 dict2 = {"a" : "grape", "d" : "orange"}4 print(dict(dict1,**dict2))5 #輸出
6 #{'a': 'apple', 'b': 'banana'}
7 #{'a': 'grape', 'b': 'banana', 'd': 'orange'}
View Code
5、使用keys()和values()獲取關(guān)鍵詞和值
d.keys()
d.values()
6、使用update()更新字典,與4的dict(dict1, **dict2)效果一樣,如果dict1與dict2含有相同的key,那么dict2的value會(huì)覆蓋dict1
1 dict1 = {"a" : "apple", "b" : "banana"}2 print(dict1)3 dict2 = {"c" : "grape", "d" : "orange"}4 dict1.update(dict2)5 print(dict1)
View Code
輸出:
{'a': 'apple', 'b': 'banana'}
{'c': 'grape', 'a': 'apple', 'b': 'banana', 'd': 'orange'}
7、使用sorted排序
#按照key排序
print(sorted(dict1.items(), key=lambda d: d[0]))
#按照value排序
print(sorted(dict1.items(), key=lambda d: d[1]))
8、使用setdefault設(shè)置默認(rèn)值
dict = {}
dict.setdefault("a")
9、pop()和clear()刪除
1 d={"a":1,"b":2,"c":3}2 print(d)3 #輸出
4 #{"a":1,"b":2,"c":3}
5
6 d1=d.pop("a") #d1=1
7 print(d)8 #輸出
9 #{"b":2,"c":3}
10
11 d2=d.pop("f",100) #d2=100
12 print(d)13 #輸出
14 #{"b":2,"c":3}
View Code
d.clear() #將字典d清空
print(d) #輸出{}
10、使用fromkeys() 函數(shù)用于創(chuàng)建一個(gè)新字典,以序列seq中元素做字典的鍵,value為字典所有鍵對(duì)應(yīng)的初始值。
1 seq={'name','age','score'}2 d=dict.fromkeys(seq,100)3 print(d)4 #輸出
5 #{'name': 100, 'age': 100, 'score': 100}
View Code
11、使用popitems()隨機(jī)返回并刪除字典中的一對(duì)鍵和值(項(xiàng))
1 seq={'name','age','score'}2 d=dict.fromkeys(seq,100)3 print(d) #輸出:{'age': 100, 'name': 100, 'score': 100}
4 d2=d.popitem()5 print(d2) #輸出:('age', 100)
6 print(d) #輸出:{'name': 100, 'score': 100}
View Code
總結(jié)
以上是生活随笔為你收集整理的pythondict(zip())_python基础:zip和dict详解的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: c盘怎么清理到最干净_C盘快满了不敢乱删
- 下一篇: python 异步io_python之同