国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

python基礎教程之字典操作詳解

2019-11-25 18:28:39
字體:
來源:轉載
供稿:網友

字典
dictionary

1.鍵值對的集合(map)

2.字典是以大括號“{}”包圍的數據集合

3.字典是無序的,在字典中通過鍵來訪問成員。 可變的,可嵌套,可以原處修改擴展等,不產生新的字典

4.字典的鍵,可以是字符串(大小寫敏感),數字常量或元組(不可變類型),同一個字典的鍵可以混用類型。字典的鍵必須是可哈希的

元組作為鍵的條件是,元組內的值都是不可變類型

復制代碼 代碼如下:

a = (1,2)  #可以作為鍵
b = (1,2,[3,4])  #不可以

5.字典的值可以是任意類型,可以嵌套,可以自由修改

聲明
創建字典的幾種方式:

1.基本

復制代碼 代碼如下:

d = {} #空字典
d = {'name':'tom', 'age':22}
#等價
d = {}
d['name'] = 'tom'
d['age'] = 22

2.dict

復制代碼 代碼如下:

d = dict() #空
d = dict(name='tom', age=22)  

d = dict([('name','tom'), ('age',22)])
#等價
keys = ['name','age']
values = ['tom', 22]
d = dict(zip(keys,values))

3.fromkeys

不指定default_value的話,默認None

復制代碼 代碼如下:

>>> dict.fromkeys(['name','age'],'default_value')
{'age': 'default_value', 'name': 'default_value'}

基本操作

0.獲取幫助

復制代碼 代碼如下:

help(dict)

1.判定鍵是否存在于字典中
復制代碼 代碼如下:

if k in d:   #k not in
    dosomething()

2.讀取

復制代碼 代碼如下:

d = {'a':1, 'b':2}
print d['a']  #得到1,但是若鍵不存在,將引發異常KeyError。慎用,建議不使用

print d.get('c', 3) #得到3,get方法,若是鍵不存在,返回第二個參數default_value.若是沒有設default_value返回None
處理missing-key錯誤三種方式,根據具體需要

復制代碼 代碼如下:

if k in d:
    print d[k]

try:
    print d[k]
except KeyError:
    dosomething()

print d.get(k, default)
#等價 d[k] if k in d else default

3.遍歷

方式1:

復制代碼 代碼如下:

for key in d:
    print key, d[key]
#等價 for key in d.keys()

方式2:

復制代碼 代碼如下:

for key,value in d.items():
    print key, value

4.修改方式1:某個鍵值對

復制代碼 代碼如下:

d['key'] = 'newvalue'

方式2:批量添加或更新

復制代碼 代碼如下:

#另一個字典
d.update({'key':'newvalue'})  #這里支持一整組值

#元組列表
d.update( [ ('a',1), ('b',2) ] ) #每個元組兩個元素,(key,value)

#**key
d.update(c=3, e=4)

5.刪除

復制代碼 代碼如下:

del d['key']
value = d.pop('key') #刪除并返回值
d.clear() #清空
6.其他:

len(d)   #長度
d.keys()  #key列表
d.values()  #value列表
d.items()   #(key, value) 列表
c = d.copy()   #淺拷貝
#返回迭代器,節省內存
d.iterkeys()
d.itervalues()
d.iteritems()
d.setdefault('name', 'ken') #若原來沒有,設置,否則原值不變

其他
1.字典排序按照key排序

復制代碼 代碼如下:

keys = d.keys()
keys.sort()
for key in keys:
    print d.get(key)

按照value進行排序

復制代碼 代碼如下:

sorted(d.items(), lambda x,y: cmp(x[1],y[1]))

另外:
復制代碼 代碼如下:

#假設d為字典
sorted(d)  #返回同 sorted(d.keys()),返回的是key排序

2.自定義對象作為key

必須:

復制代碼 代碼如下:

def __hash__(self):
    pass
def __eq__(self, other):
    pass

3.字典拷貝淺拷貝:

復制代碼 代碼如下:

c = d.copy() #

深拷貝必須用copy模塊
復制代碼 代碼如下:

form copy import deepcopy
c = deepcopy(d)

4.一種使用場景假設有一個很大的列表l,假設10w條記錄

有一個小列表b,要判斷b中元素是否在l中

如果:

復制代碼 代碼如下:

for i in b:
    if i in l:
        dosomething()

你會發現非常非常慢...因為第二個in語句,會遍歷10w條….

改進:

復制代碼 代碼如下:

d = dict.fromkeys(l)
for i in b:
    if i in d:
        dosomething()
#空間換時間,O(n) -> O(1)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 横山县| 榆林市| 阆中市| 聊城市| 潜江市| 丰原市| 新建县| 江北区| 琼海市| 德格县| 措美县| 祁连县| 霍州市| 高淳县| 沈阳市| 蒲江县| 巢湖市| 怀安县| 苏尼特左旗| 兴隆县| 台湾省| 涪陵区| 昔阳县| 沾益县| 长垣县| 教育| 佳木斯市| 工布江达县| 昌图县| 大连市| 阿拉尔市| 崇州市| 汨罗市| 西城区| 依安县| 印江| 美姑县| 石河子市| 黄浦区| 日照市| 景泰县|