一. 字典的簡單介紹 1,字典(dict)是python中唯一的一個映射類型.他是以{ }括起來的鍵值對組成. 在dict中key是 唯一的. 在保存的時候, 根據key來計算出一個記憶體地址. 然後將key-value保存在這個地址中. 這種演算法被稱為hash演算法, 所以, 切記, 在dict中存儲 ...
一. 字典的簡單介紹
1,字典(dict)是python中唯一的一個映射類型.他是以{ }括起來的鍵值對組成. 在dict中key是 唯一的.
在保存的時候, 根據key來計算出一個記憶體地址.
然後將key-value保存在這個地址中. 這種演算法被稱為hash演算法, 所以, 切記, 在dict中存儲的key-value
中的key'必須是可hash的, 如果你搞不懂什什麽
是可哈希, 暫時可以這樣記, 可以改變的都是不可哈希的, 那麼可哈希就意味著不可變. 這個是為了能
準確的計算記憶體地址而規定的.
2. 已知的可哈希(不可變)的數據類型: int, str, tuple, bool
不可哈希(可變)的數據類型: list, dict, set
3.語法 : {key1: value1, key2: value2....}
# 合法 dic = {123: 456, True: 999, "id": 1, "name": 'sylar', "age": 18, "stu": ['帥 哥', '美女'], (1, 2, 3): '麻花藤'} print(dic[123]) print(dic[True]) print(dic['id']) print(dic['stu']) print(dic[(1, 2, 3)]) # 不合法 # dic = {[1, 2, 3]: '周傑倫'} # list是可變的. 不能作為key # dic = {{1: 2}: "哈哈哈"} # dict是可變的. 不能作為key dic = {{1, 2, 3}: '呵呵呵'} # set是可變的, 不不能作為key
註意:dict保存的數據不是按照我們添加進去的順序保存的. 是按照hash表的順序保存的. 而hash表
不是連續的. 所以不能進行切片工作. 它只能通過key來獲取dict中的數據
二. 字典的增刪改查和其他相關操作
1增加:
dic = {} dic['name'] = '周潤發' # 如果dict中沒有出現這個key, 就會新增一個key-value的組合進dict dic['age'] = 18 print(dic) # 如果dict中沒有出現過這個key-value. 可以通過setdefault設置預設值 dic.setdefault('李嘉誠') # 也可以往里面設置值,當字典中沒有該key時,返回設置的value. dic.setdefault("李嘉誠", "房地產") # 如果dict中已經存在了. 那麼setdefault將不會起作用 print(dic)
2. 刪除
ret = dic.pop("jay") print(ret) del dic["jay"] print(dic) # 隨機刪除. ret = dic.popitem() # 清空字典中的所有內容 dic.clear()
3. 修改
dic = {"id": 123, "name": 'sylar', "age": 18} dic1 = {"id": 456, "name": "麻花藤", "ok": "wtf"} dic.update(dic1) # 把dic1中的內容更新到dic中. 如果key重名. 則修改替換. 如果不存在key, 則新增. print(dic) print(dic1)
4. 查詢
查詢一般用key來查找具體的數據.
dic = {123: 456, True: 999, "id": 1, "name": 'sylar', "age": 18, "stu": ['帥 哥', '美女'], (1, 2, 3): '麻花藤'} print(dic['name']) # print(dic['sylar']) # 報錯 print(dic.get("ok")) print(dic.get("sylar")) # None print(dic.get("sylar", "牛B")) # 牛B
註意:setdefault()
1>先判斷原子典中是否有key,若沒有執行新增,若有不增加;
2>用此key去字典中查詢,返回查詢結果
5. 其他相關操作
dic = {"id": 123, "name": 'sylar', "age": 18, "ok": "科比"} print(dic.keys()) # dict_keys(['id', 'name', 'age', 'ok']) 不用管它是什麽.當 成list來用就行 for key in dic.keys(): print(key) print(dic.values()) # dict_values([123, 'sylar', 18, '科比']) 一樣. 也當 list來用 for value in dic.values(): print(value) print(dic.items()) # dict_items([('id', 123), ('name', 'sylar'), ('age', 18), ('ok', '科比')]) 這個東西也是list. 只不過list中裝的是tuple for key, value in dic.items(): # 這個是解構 print(key, value) # 解構 a, b = 1, 2 print(a, b) (c, d) = 3, 4 print(c, d) e, f = [1, 2, 3] # 解構的時候註意數量量必須匹配 print(e, f)
三. 字典的嵌套
# 字典的嵌套 dic1 = { "name": "汪峰", "age": 18, "wife": { "name": '章子怡', "age": 28 }, "children": ['第一個毛孩子', '第二個毛孩子'], "desc": '峰 哥不會告我吧. 沒關係. 我想上頭條的' } print(dic1.get("wife").get("name")) print(dic1.get("children")) print(dic1.get("children")[1])