python数据类型三(字典)
一、字典的介绍
字典(dict)是python中唯一的一个映射类型,它是以{}括起来的键值对组成,在dict中key是唯一的,在保存的时候,根据key来计算出一个内存地址,然后将key-value保存在这个地址中,这种算法被称为hash算法,所以,切记,在dict中存储的key-value中的key必须是可hash的,如果你搞不懂什么是可哈希,暂时可以这样记:可以改变的都是不可哈希的,那么可哈希就意味着不可变。这个是为了能准确的计算内存地址而规定的。
已知的可哈希(不可变)的数据类型:int,str,bool,tuple
不可哈希(可变)的数据类型:list,dict,set
语法:{key1: value1, key2: value2, … }
注意:key必须是不可变(可哈希)的,value没有要求,可以保存任意类型的数据。
# 合法 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)]) # 不合法 dic1 = {[1, 2, 3]: '周杰伦'} # list是可变的. 不能作为key dic2 = {{1: 2}: "哈哈哈"} # dict是可变的. 不能作为key dic3 = {{1, 2, 3}: '呵呵呵'} # set是可变的. 不能作为key
dict保存的数据不是按照我们添加进去的顺序保存的,是按照hash(可哈希)表的顺序,而hash(可哈希)表不是连续的,所以dict不能进行切片工作,它只能通过key来获取dict中的数据。
二、字典的增、删、改、查和其他相关操作
2.1 增
字典的增加操作有:dic[key] = value,dic.setdefault(key, value),具体用法如下示例:
dic = {} dic['name'] = '周润发' # 如果dict中没有出现这个key, 就会新增一个key-value组合,如果dict中已经有这个key了,那么将会覆盖原来的值 dic['age'] = 18 print(dic) # 结果为:{'name':'周润发', 'age':18}
# 如果dict中没有出现过这个key-value. 可以通过setdefault设置默认值 dic.setdefault('李嘉诚') # 也可以往里面设置值,dict中增加键值对 "李嘉诚":None,返回值是None print(dic) # 结果为:{'name':'周润发', 'age':18, '李嘉诚':None}
dic.setdefault("李嘉诚", "房地产") # 如果dict中已经有这个key了. 那么setdefault将不会起作用,返回值是这个key对应的dict中的value值 print(dic) # 结果为:{'name':'周润发', 'age':18, '李嘉诚':None}
dic.setdefault("李嘉", "18") # dict中增加键值对 "李嘉":"18",返回值是18 print(dic) # 结果为:{'name':'周润发', 'age':18, '李嘉诚':None, '李嘉':'18'}
2.2 删除
字典的删除操作有:pop[key],del dic[key],popitem(),clear,具体用法如下示例:
dic = {"jay":"who", "i":"wang", "zhao":"jie", "niu":"li"} ret = dic.pop("jay") # pop有返回值,返回被删除的value值 print(ret) # 结果为:who
del dic["i"] print(dic) # {'zhao':'jie','niu':'li'}
ret = dic.popitem() # 随机删除,返回一个元组(删除的key , 删除的value),可以用解构 k , v = dic.popitem() print(ret) # 结果为:('niu', 'li')
dic.clear() # 清空字典 print(dic) # {}
dic.pop()必须有一个参数key,即要删除的元素的key,否则报错,而list.pop()不带参数默认删除最后一个元素。
2.3 修改
字典的修改操作有:dic[key] = value,dic.update(),具体如下示例代码:
dic0 = {"1":"张三", "2":"李四"} dic0["2"] = "王五" # 强制修改 print(dic0) # 结果为:{'1':'张三', '2':'王五'} dic = {"id":123, "name":'sylar', "age":18} dic1 = {"id":456, "name":"麻花藤", "ok":"wtf"} dic.update(dic1) # 把dic1中的内容更新到dic中. 如果key重名. 则修改替换. 如果不存在key, 则新增. print(dic) # 结果为:{'id':456, 'name':'麻花藤', 'age':18, 'ok':'wtf'} print(dic1) # 结果为:{'id':456, 'name':'麻花藤', 'ok':'wtf'}
2.4 查询
查询一般用key来查找具体的数据,如get(key),dic[key],setdefault(key),还有for循环,具体如下:
dic = {"id": 123, "name": 'sylar', "age": 18} print(dic['name']) # print(dic['ok']) # 没有这个键的时候会报错 KeyError print(dic.get("ok")) # 没有这个键的时候返回None print(dic.get("ok", "牛B")) # 没有这个键时,第二参数可以指定返回内容,原dict内容不变,此打印结果为:牛B print(dic.setdefault("ok")) # 没有这个键的时候会为dict增加键值对"ok":None,并返回None,即此打印结果是None
dic = {"id":123, "name":"sylar" , "age":18} for i in dic: print(i) # 获取到的是 key print(dic[i]) # 获取到的 value
2.5 其他操作
keys 获取到所有的键存在一个高仿的列表中;
values 获取到所有的值存在一个高仿的列表中;
items 获取到所有的键值对以元组的形式存在一个高仿的列表中;
具体用法如下示例:
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) # 1 2 (c, d) = 3, 4 print(c, d) # 3 4 e, f = [1, 2, 3] # 解构的时候注意数量必须匹配,所以这样写不对
三、字典的嵌套
字典的嵌套示例如下:
# 字典的嵌套 dic1 = { "name": "汪峰", "age": 43, "wife": { "name": '章子怡', "age": 39 }, "children": ['第一个孩子', '第二个孩子'], "desc": '峰哥不会告我吧. 没关系的' } print(dic1.get("wife").get("name")) print(dic1.get("children")) print(dic1.get("children")[1]