Python的字典是一种Key-value的数据类型,和js的数据格式一样。
name = {
‘name‘:‘zhangshan‘,
‘age‘:23,
‘address‘:‘beijing‘,
54:‘asd‘,
‘address‘:‘hebei‘
} print(name)#{‘name‘: ‘zhangshan‘, 54: ‘asd‘, ‘address‘: ‘hebei‘, ‘age‘: 23
1、打印的结果和我定义字典的顺序不一样,说明字典是无序的。
2、定义了两个‘address‘ 最后定义的把之前的覆盖了 说明字典的key是唯一的。
dic[key] = value
name = { ‘name‘:‘zhangshan‘, ‘age‘:23, ‘address‘:‘beijing‘, 54:‘asd‘, ‘address‘:‘hebei‘ } name[‘phone‘]=‘789456‘ print(name)#{‘phone‘: ‘789456‘, ‘age‘: 23, ‘name‘: ‘zhangshan‘, ‘address‘: ‘hebei‘, 54: ‘asd‘}
pop(key) 删除指定的key
name = { ‘name‘:‘zhangshan‘, ‘age‘:23, ‘address‘:‘beijing‘, } name.pop(‘age‘) print(name)#{‘name‘: ‘zhangshan‘, ‘address‘: ‘beijing‘}
dic[key] = new_value
name = { ‘name‘:‘zhangshan‘, ‘age‘:23, ‘address‘:‘beijing‘, } name[‘name‘] = ‘lisi‘ print(name)#{‘age‘: 23, ‘name‘: ‘lisi‘, ‘address‘: ‘beijing‘}
字典的查找
1 dic[key]
name = { ‘name‘:‘zhangshan‘, ‘age‘:23, ‘address‘:‘beijing‘, } print(name[‘name‘])#zhangshan
这种方法不是很好,如果查一个不存在的key会报错。
name = { ‘name‘:‘zhangshan‘, ‘age‘:23, ‘address‘:‘beijing‘, } print(name[‘idcode‘])
2 get(key) 如果有了就返回 没有了就是none
name = { ‘name‘:‘zhangshan‘, ‘age‘:23, ‘address‘:‘beijing‘, } print(name.get(‘idcode‘))#None
3 in 判断这个key是不是在字典中 结果是布尔值
name = { ‘name‘:‘zhangshan‘, ‘age‘:23, ‘address‘:‘beijing‘, } print(‘idcode‘ in name)#False print(‘address‘ in name)#True
values() 打印所有的value
name = { ‘name‘:‘zhangshan‘, ‘age‘:23, ‘address‘:‘beijing‘, } print(name.values())#dict_values([23, ‘zhangshan‘, ‘beijing‘])
keys() 打印所有的key
name = { ‘name‘:‘zhangshan‘, ‘age‘:23, ‘address‘:‘beijing‘, } print(name.keys())#dict_keys([‘age‘, ‘address‘, ‘name‘])
setdefault(key,value) 先查字典,如果能查到有这个key就返回,没有就创建一个新的key,赋值value。
name = { ‘name‘:‘zhangshan‘, ‘age‘:23, ‘address‘:‘beijing‘, } name.setdefault(‘phone‘,‘789456‘) name.setdefault(‘age‘,25) print(name)#{‘phone‘: ‘789456‘, ‘age‘: 23, ‘name‘: ‘zhangshan‘, ‘address‘: ‘beijing‘}
update(dic) 两个字典合并,相同的元素覆盖。
name = { ‘name‘:‘zhangshan‘, ‘age‘:23, ‘address‘:‘beijing‘, } name2 = { ‘name‘:‘lisi‘, ‘phone‘:‘456456‘, ‘car‘:‘SKODA‘ } name.update(name2) print(name)#{‘age‘: 23, ‘phone‘: ‘456456‘, ‘name‘: ‘lisi‘, ‘car‘: ‘SKODA‘, ‘address‘: ‘beijing‘}
items() 字典转列表,每一组key-value 转成元组,key作为元组的第一个值,value作为元组的第二个值。
name2 = { ‘name‘:‘lisi‘, ‘phone‘:‘456456‘, ‘car‘:‘SKODA‘ } print(name2.items())#dict_items([(‘phone‘, ‘456456‘), (‘car‘, ‘SKODA‘), (‘name‘, ‘lisi‘)])
如果是字典嵌套
name2 = { ‘name‘:‘lisi‘, ‘phone‘:‘456456‘, ‘car‘:‘SKODA‘, ‘child‘:{ ‘key_1‘:1 } } print(name2.items())#dict_items([(‘car‘, ‘SKODA‘), (‘child‘, {‘key_1‘: 1}), (‘name‘, ‘lisi‘), (‘phone‘, ‘456456‘)])
可以看到, 嵌套的字典并没有转成元组。
1、简单的for循环
name = { ‘name‘:‘zhangshan‘, ‘age‘:23, ‘address‘:‘beijing‘, } for i in name: print(i,name[i]) ##################### name zhangshan age 23 address beijing
2、items() 转列表循环
for key,value in name.items(): print(key,value ) ####################### address beijing name zhangshan age 23
如果数据量很大的话,转列表的操作会很低效。
原文:http://www.cnblogs.com/qing-chen/p/7196042.html