Python字典是另外一種可變容器模型,且可存儲任意類型對象,如字符串、數字、元組等其餘容器模型。html
字典由鍵和對應值成對組成。字典也被稱做關聯數組或哈希表。基本語法以下:python
dict = {'Alice': '2341', 'Beth': '9102', 'Cecil': '3258'} # 也可如此建立字典 dict1 = { 'abc': 456 } dict2 = { 'abc': 123, 98.6: 37 }
注意:ios
每一個鍵與值用冒號隔開(:),每對用逗號,每對用逗號分割,總體放在花括號中({})。json
鍵必須獨一無二,但值則沒必要。數組
值能夠取任何數據類型,但必須是不可變的,如字符串,數或元組。函數
把相應的鍵放入熟悉的方括弧,以下實例:spa
dict = {'Name': 'Zara', 'Age': 7, 'Class': 'First'} print ("dict['Name']: ", dict['Name']) print ("dict['Age']: ", dict['Age'] ) #以上實例輸出結果: #dict['Name']: Zara #dict['Age']: 7
若是用字典裏沒有的鍵訪問數據,會輸出錯誤以下:.net
dict = {'Name': 'Zara', 'Age': 7, 'Class': 'First'} print ("dict['Alice']: ", dict['Alice'] ) # 以上實例輸出結果: #KeyError: 'Alice'
向字典添加新內容的方法是增長新的鍵/值對,修改或刪除已有鍵/值對以下實例:code
dict = {'Name': 'Zara', 'Age': 7, 'Class': 'First'} dict['Age'] = 8; # update existing entry dict['School'] = "DPS School"; # Add new entry print ("dict['Age']: ", dict['Age']) print ("dict['School']: ", dict['School']) #以上實例輸出結果: #dict['Age']: 8 #dict['School']: DPS School
能刪單一的元素也能清空字典,清空只需一項操做。htm
顯示刪除一個字典用del命令,以下實例:
dict = {'Name': 'Zara', 'Age': 7, 'Class': 'First'} del dict['Name'] # 刪除鍵是'Name'的條目 dict.clear() # 清空詞典全部條目 KeyError: 'Age' del dict # 刪除詞典 TypeError: 'type' object is not subscriptable print ("dict['Age']: ", dict['Age']) # 但這會引起一個異常,由於用del後字典再也不存在
字典值能夠沒有限制地取任何python對象,既能夠是標準的對象,也能夠是用戶定義的,但鍵不行。
兩個重要的點須要記住:
1)不容許同一個鍵出現兩次。建立時若是同一個鍵被賦值兩次,後一個值會被記住,以下實例:
dict = {'Name': 'Zara', 'Age': 7, 'Name': 'Manni'} print("dict['Name']: ", dict['Name']) #以上實例輸出結果: #dict['Name']: Manni
2)鍵必須不可變,因此能夠用數,字符串或元組充當,因此用列表就不行,以下實例:
dict = {['Name']: 'Zara', 'Age': 7} print("dict['Name']: ", dict['Name']) # 以上實例輸出結果: # TypeError: unhashable type: 'list'
Python字典包含了如下內置函數:
cmp(dict1, dict2) #比較兩個字典元素。
len(dict) #計算字典元素個數,即鍵的總數。
str(dict) #輸出字典可打印的字符串表示。
type(variable) #返回輸入的變量類型,若是變量是字典就返回字典類型。
參考連接:https://www.cnblogs.com/scios/p/8108243.html
通常有兩種通用作法:
第一種方法:使用自帶函數實現:
在python的字典的屬性方法裏面有一個has_key()方法:
#生成一個字典 d = {'name':Tom, 'age':10, 'Tel':110} #打印返回值 print d.has_key('name') #結果返回True
第二種方法:使用in方法:
#生成一個字典 d = {'name':Tom, 'age':10, 'Tel':110} #打印返回值,其中d.keys()是列出字典全部的key print ‘name’ in d.keys() print 'name' in d #兩個的結果都是返回True
除了使用in還可使用not in,斷定這個key不存在,使用in要比has_key要快。
參考連接:https://blog.csdn.net/tao546377318/article/details/52160942
先說幾個解決的方法,具體的有時間再細說
d = {'a':1,'b':4,'c':2}
字典是這個,而後要對字典按照value進行排序
方法一:
sorted(d.items(),key = lambda x:x[1],reverse = True)
方法二:
import operator sorted(d.items(),key = operator.itemgetter(1))
方法三:
f = zip(d.values(),d.keys())
sorted(f)
//結果是 [(1, 'a'), (2, 'c'), (4, 'b')]
zip 以後,zip函數默認會對第一個元素進行排序的,如何取消排序?
參考連接:https://www.cnblogs.com/timtike/p/6562402.html
OrderedDict是dict的子類,它記住了內容添加的順序。
dict自己是無序的,OrderedDict之因此能記住順序,是將對應關係轉化爲元組進行存儲,順序經過列表來記錄,以此實現保持原有順序的功能
OrderedDict([(3, 'A'), (2, 'B'), (1, 'C')])
而原字典的存儲形式是這樣的
{1: 'C', 2: 'B', 3: 'A'}
比較時,OrderedDict要內容和順序徹底相同纔會視爲相等。
示例:
import collections d = collections.OrderedDict() d[3] = 'A' d[2] = 'B' d[1] = 'C' for k, v in d.items(): print(k, v)
結果是順序(按程序讀取順序輸出)
而若是d是通常的dict,則結果是逆序(輸出順序與key值有關)
import json from collections import OrderedDict metadata = json.loads(text, object_pairs_hook=OrderedDict);
metadata中properties的順序是跟text中定義的順序是同樣的。
具體能夠看python文檔中json.loads函數中的參數。
參考連接: https://blog.csdn.net/yockie/article/details/44065885