跟老齊學Python之dict()的操作方法

來源:互聯網
上載者:User
dict的很多方法跟list有類似的地方,下面一一道來,並且會跟list做一個對比

嵌套

嵌套在list中也存在,就是元素是list,在dict中,也有類似的樣式:

>>> a_list = [[1,2,3],[4,5],[6,7]]>>> a_list[1][1]5>>> a_dict = {1:{"name":"qiwsir"},2:"python","email":"qiwsir@gmail.com"}>>> a_dict{1: {'name': 'qiwsir'}, 2: 'python', 'email': 'qiwsir@gmail.com'}>>> a_dict[1]['name']  #一個嵌套的dict訪問其值的方法:一層一層地寫出鍵'qiwsir'

擷取鍵、值

在上一講中,已經知道可以通過dict的鍵得到其值。例上面的例子。

還有別的方法得到索引值嗎?有!python一般不是只有一個方法實現某個操作的。

>>> website = {1:"google","second":"baidu",3:"facebook","twitter":4}>>>#用d.keys()的方法得到dict的所有鍵,結果是list>>> website.keys()[1, 'second', 3, 'twitter']>>>#用d.values()的方法得到dict的所有值,如果裡面沒有嵌套別的dict,結果是list>>> website.values()['google', 'baidu', 'facebook', 4]>>>#用items()的方法得到了一組一組的索引值對,>>>#結果是list,只不過list裡面的元素是元組>>> website.items()[(1, 'google'), ('second', 'baidu'), (3, 'facebook'), ('twitter', 4)]

從上面的結果中,我們就可以看出,還可以用for語句迴圈得到相應內容。例如:

>>> for key in website.keys():...   print key,type(key)... 1 second 3 twitter >>>#下面的方法和上面的方法是一樣的>>> for key in website:...   print key,type(key)... 1 second 3 twitter 

以下兩種方法等效:

>>> for value in website.values():...   print value... googlebaidufacebook4>>> for key in website:...   print website[key]... googlebaidufacebook4

下面的方法又是等效的:

>>> for k,v in website.items():...   print str(k)+":"+str(v)... 1:googlesecond:baidu3:facebooktwitter:4>>> for k in website:...   print str(k)+":"+str(website[k])... 1:googlesecond:baidu3:facebooktwitter:4

下面的方法也能得到索引值,不過似乎要多敲鍵盤

>>> website{1: 'google', 'second': 'baidu', 3: 'facebook', 'twitter': 4}>>> website.get(1)   'google'>>> website.get("second")'baidu'

其它幾種常用方法

dict中的方法在這裡不做過多的介紹,因為前面一節中已經列出來類,看官如果有興趣可以一一嘗試。下面列出幾種常用的

>>> len(website)4>>> website{1: 'google', 'second': 'baidu', 3: 'facebook', 'twitter': 4}>>> new_web = website.copy()  #拷貝一份,這個拷貝也叫做淺拷貝,對應著還有深拷貝。>>> new_web           #兩者區別,可以google一下。{1: 'google', 'second': 'baidu', 3: 'facebook', 'twitter': 4}

刪除索引值對的方法有兩個,但是兩者有一點區別

>>>#d.pop(key),根據key刪除相應的索引值對,並返回該值>>> new_web.pop('second')'baidu'>>> del new_web[3]   #沒有傳回值,如果刪除鍵不存在,返回錯誤>>> new_web{1: 'google', 'twitter': 4}>>> del new_web[9]Traceback (most recent call last):File "", line 1, in KeyError: 9

用d.update(d2)可以把d2合并到d中。

>>> cnweb{'qq': 'first in cn', 'python': 'qiwsir.github.io', 'alibaba': 'Business'}>>> website{1: 'google', 'second': 'baidu', 3: 'facebook', 'twitter': 4}>>> website.update(cnweb)  #把cnweb合并到website內>>> website         #變化了{'qq': 'first in cn', 1: 'google', 'second': 'baidu', 3: 'facebook', 'python': 'qiwsir.github.io', 'twitter': 4, 'alibaba': 'Business'}>>> cnweb          #not changed{'qq': 'first in cn', 'python': 'qiwsir.github.io', 'alibaba': 'Business'}

在本講最後,要提醒看官,在python3中,dict有不少變化,比如能夠進行字典解析,就類似列表解析那樣,這可是非常有意思的東西哦。

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.