首頁 >後端開發 >Python教學 >python字典的鍵可以是列表嗎

python字典的鍵可以是列表嗎

silencement
silencement原創
2019-06-17 14:45:0728055瀏覽

python字典的鍵可以是列表嗎

python字典的鍵

字典中的值沒有任何限制, 可以是任意Python對象,即從標準對像到使用者自訂物件皆可,但是字典中的鍵是有型別限制的。

不允許一個鍵對應多個值

必須明確一條原則:每個鍵只能對應一個項。也就是說:一鍵對應多個值是不允許的(像列表、元組和其他字典這樣的容器物件是可以的)。當有鍵發生衝突(即字典鍵重複賦值),取最後(最近)的賦值。 Python並不會因為字典中的鍵存在衝突而產生一個錯誤,它不會檢查鍵的衝突是因為如果真這樣做的話,在每個鍵-值對賦值的時候都會做檢查,這將會佔用一定量的內存。

>>> dict1 = {'foo':789, 'foo': 'xyz'} 
>>> dict1 
{'foo': 'xyz'} 
>>> dict1['foo'] = 123
>>> dict1 
{'foo': 123}

鍵必須是可哈希的

大多數Python物件可以作為鍵,但它們必須是可哈希的物件。像列表和字典這樣的可變類型,由於它們不是可哈希的,所以不能作為鍵。    所有不可變的類型都是可哈希的,因此它們都可以做為字典的鍵。要說明的是:值相等的數字表示相同的鍵,即整數數字1和浮點數1.0的雜湊值是相同的,它們是相同的鍵。

 同時,也有一些可變物件(很少)是可哈希的,它們可以做字典的鍵,但很少見。舉一個例子,一個實作了__hash__() 特殊方法的類別。因為__hash__()方法傳回一個整數,所以仍然是用不可變的值(做字典的鍵)。      為什麼鍵必須是可哈希的?解釋器呼叫雜湊函數,根據字典中鍵的值來計算儲存你的資料的位置。如果鍵是可變對象,它的值可改變。如果鍵發生變化,則雜湊函數會對應到不同的位址來儲存資料。如果這樣的情況發生,雜湊函數就不可能可靠地儲存或取得相關的資料。選擇可哈希的鍵的原因是因為它們的值不能改變。

數字和字串可以用做字典的鍵,元組是不可變的但也可能不是一成不變的,因此用元組做有效的鍵必須要加限制:若元組中只包括像數字和字串這樣的不可變參數,才可以作為字典中有效的鍵。

以上是python字典的鍵可以是列表嗎的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

相關文章

看更多