天天看點

Python字典的内置方法

字典由key和value組成,key必須唯一,值可以不唯一。字典是無序的。

字典常用的方法:

clear():

清除字典中的所有内容

1

2

3

4

<code> </code><code>&gt;&gt;&gt; dic1={</code><code>"name"</code><code>:</code><code>"zeng"</code><code>,</code><code>"age"</code><code>:28}       </code>

<code>    </code><code>&gt;&gt;&gt; dic1.</code><code>clear</code><code>()</code>

<code>    </code><code>&gt;&gt;&gt; dic1</code>

<code>    </code><code>{}</code>

items()

擷取字典的key和value,結果為清單

<code>&gt;&gt;&gt; dic</code>

<code>{</code><code>'liu'</code><code>: 23, </code><code>'zhou'</code><code>: 22, </code><code>'zeng'</code><code>: 21}</code>

<code>&gt;&gt;&gt; dic.items()</code>

<code>[(</code><code>'liu'</code><code>, 23), (</code><code>'zhou'</code><code>, 22), (</code><code>'zeng'</code><code>, 21)]</code>

get():

擷取字典中指定key對應的值。與dic[‘key’]作用一樣,但不同的是,如果key不存在不會報錯,傳回的是None 

<code>&gt;&gt;&gt; dic={</code><code>'k1'</code><code>:1234}</code>

<code>&gt;&gt;&gt; dic.get(</code><code>'k1'</code><code>)</code>

<code>1234</code>

如果希望key不存在時,傳回自定義的值,可以這樣

<code>&gt;&gt;&gt; dic.get(</code><code>'k2'</code><code>,</code><code>'ok'</code><code>)</code>

<code>'ok'</code>

字典指派:

<code>&gt;&gt;&gt; dic[</code><code>'k2'</code><code>]=4567</code>

<code>{</code><code>'k2'</code><code>: 4567, </code><code>'k1'</code><code>: 1234}</code>

 判斷是否為字典

<code>&gt;&gt;&gt; </code><code>type</code><code>(dic) is dict</code>

<code>True</code>

fromkeys(list,value):  

用清單中的每一個值當做key,後面的值當做value,生成一個字典  

<code>&gt;&gt;&gt; a={}</code>

<code>&gt;&gt;&gt; a.fromkeys([</code><code>'zeng'</code><code>,</code><code>'zhou'</code><code>,</code><code>'liu'</code><code>],</code><code>'Defensor'</code><code>)</code>

<code>{</code><code>'liu'</code><code>: </code><code>'Defensor'</code><code>, </code><code>'zhou'</code><code>: </code><code>'Defensor'</code><code>, </code><code>'zeng'</code><code>: ‘Defensor'}</code>

has_key(k):

檢查字典中是否指定的key,也可以用 "key in dict" 來判斷

5

6

<code>&gt;&gt;&gt; b</code>

<code>{</code><code>'liu'</code><code>: </code><code>'Defensor'</code><code>, </code><code>'zhou'</code><code>: </code><code>'Defensor'</code><code>, </code><code>'zeng'</code><code>: </code><code>'Defensor'</code><code>}</code>

<code>&gt;&gt;&gt; b.has_key(</code><code>'zeng'</code><code>)</code>

<code>&gt;&gt;&gt; </code><code>"liu"</code> <code>in</code> <code>b</code>

keys():列印字典中所有的key

pop(k):删除指定的鍵值對, 并列印出删除的值

<code>&gt;&gt;&gt; b.pop(</code><code>'liu'</code><code>)</code>

<code>‘Defensor'</code>

字典的循環和取值

第一種方法:

<code>&gt;&gt;&gt; </code><code>for</code> <code>k </code><code>in</code> <code>b:print k,b[k]</code>

<code>... </code>

<code>liu Defensor</code>

<code>zeng Defensor</code>

<code>zhou Defensor</code>

第二種方法:

<code>&gt;&gt;&gt; </code><code>for</code> <code>k,</code><code>v</code> <code>in</code> <code>dic.items():print k,</code><code>v</code>

<code>liu 23</code>

<code>zhou 22</code>

<code>zeng 21</code>

這兩種方法的差別:第二種方法在字典資料量太大,如上百萬條時,需要将字典先轉換成清單,再處理。是以處理很慢,且影響性能。

pop()

删除給定key的鍵值對,并傳回結果

<code>&gt;&gt;&gt; dic.pop(</code><code>'liu'</code><code>)</code>

<code>23</code>

<code>{</code><code>'zhou'</code><code>: 22, </code><code>'zeng'</code><code>: 21}</code>

popitem():

随機删除鍵值對 

<code>{</code><code>'liu'</code><code>: 30, </code><code>'zhou'</code><code>: 22, </code><code>'zeng'</code><code>: 21}</code>

<code>&gt;&gt;&gt; dic.popitem()</code>

<code>(</code><code>'liu'</code><code>, 30)</code>

setdefault(key):

如果字典中有指定的key,則列印該key對應的value,如果沒有這個key,則建立一個鍵值對,value為

None

7

<code>&gt;&gt;&gt; dic.setdefault(</code><code>'liu'</code><code>)</code>

<code>{</code><code>'liu'</code><code>: None, </code><code>'zhou'</code><code>: 22, </code><code>'zeng'</code><code>: 21}</code>

<code>&gt;&gt;&gt; dic.setdefault(</code><code>'zeng'</code><code>)</code>

<code>21</code>

setdefault(key,value):

如果字典中有指定的key,則傳回該key對應的value,如果沒有這個key,則建立一個鍵值對 ,并傳回value

8

<code>&gt;&gt;&gt; dic.setdefault(</code><code>'yin'</code><code>,20)</code>

<code>20</code>

<code>{</code><code>'liu'</code><code>: None, </code><code>'yin'</code><code>: 20, </code><code>'zhou'</code><code>: 22, </code><code>'zeng'</code><code>: 21}</code>

<code>&gt;&gt;&gt; dic.setdefault(</code><code>'zhou'</code><code>,25)</code>

<code>22</code>

dica.pdate(dictb) : 

循環dictb中的每一個key是否在dicta中存在,如不存在,則将dictb中的鍵值對加入到dicta中。如果key在dicta中存在,則将dicta中的key的值改成dictb中同一個key對應的值

<code>&gt;&gt;&gt; a={1:1,2:2}</code>

<code>&gt;&gt;&gt; b={1:11,2:2,3:3}</code>

<code>&gt;&gt;&gt; a.update(b)</code>

<code>&gt;&gt;&gt; a</code>

<code>{1: 11, 2: 2, 3: 3}</code>

copy() 和deepcopy()  深複制和淺複制

利用切片操作和工廠方法list方法拷貝就叫淺拷貝,隻是拷貝了最外圍的對象本身,内部的元素都隻是拷貝了一個引用而已。 

利用copy中的deepcopy方法進行拷貝就叫做深拷貝,外圍和内部元素都進行了拷貝對象本身,而不是引用。

9

10

11

<code>&gt;&gt;&gt; </code><code>import</code> <code>copy</code>

<code>&gt;&gt;&gt; jack = [</code><code>'jack'</code><code>,[</code><code>'age'</code><code>,</code><code>'20'</code><code>]]</code>

<code>&gt;&gt;&gt; tom = copy.deepcopy(jack)</code>

<code>&gt;&gt;&gt; anny = copy.copy(jack)</code>

<code>&gt;&gt;&gt; tom[0]=</code><code>'tom'</code>

<code>&gt;&gt;&gt; anny[0]=</code><code>'anny'</code>

<code>&gt;&gt;&gt; print jack,tom,anny</code>

<code>[</code><code>'jack'</code><code>, [</code><code>'age'</code><code>, </code><code>'20'</code><code>]] [</code><code>'tom'</code><code>, [</code><code>'age'</code><code>, </code><code>'20'</code><code>]] [</code><code>'anny'</code><code>, [</code><code>'age'</code><code>, </code><code>'20'</code><code>]]</code>

<code>&gt;&gt;&gt; anny[1][1] = 18</code>

<code>[</code><code>'jack'</code><code>, [</code><code>'age'</code><code>, 18]] [</code><code>'tom'</code><code>, [</code><code>'age'</code><code>, </code><code>'20'</code><code>]] [</code><code>'anny'</code><code>, [</code><code>'age'</code><code>, 18]]</code>

淺拷貝圖解 

<a href="http://s3.51cto.com/wyfs02/M02/82/F0/wKioL1dmW97SWXM5AACRrD8T_rg303.png" target="_blank"></a>

本文轉自 曾哥最愛 51CTO部落格,原文連結:http://blog.51cto.com/zengestudy/1790817,如需轉載請自行聯系原作者