一. 主要内容
字典 dict 用{}括起来 键值对 key:value {key:value}
键 唯一性 可哈希 不可变得数据类型可以当做字典的键
值 没人任何限制
增
dic[key] = value 当这个键没在字典中就是添加
dic.setdefault(key,value) 如果这个键在字典中存在,value就不会代替原有的值
删
pop(key) 返回值 返回被删除的键值对中的值
del dic[key]
clear() 清空
popitem() 随机删除
改
dic[key] = value 当这个键在字典中存在时,强行修该value
dic.update(dict)
查:
dic.get(key)
setdefault()
for 循环 所以的key
print(dic[key])
其他:
keys 获取到字典中所有的key 然后存在一个高仿的列表中
values 获取到字典中所有的value 然后存在一个高仿的列表中
items 获取到所有的键值对,已元组的形式存放在高仿的列表中
解构:
a,b = 1,2
a,b = ('1',2)
a,b = [1,2]
a,b = '12'
字典的嵌套:
dic = {
'name':'汪峰',
'age':43,
'wife':{
'name':'国际章',
'age':39,
'salary':100000
},
'baby':[
{'name':'熊大','age':18},
{'name':'熊二','age':15},
]
}
dic['baby'][0]['age'] = 19
print(dic)
二. 练习内容
# 默认界面
# Settings -- Editor -- File and Code Templates
# 加油,
'''
⼀一. 字典的简单介绍
字典(dict)是python中唯⼀一的⼀一个映射类型.他是以{ }括起来的键值对组成. 在dict中key是
唯⼀一的. 在保存的时候, 根据key来计算出⼀一个内存地址. 然后将key-value保存在这个地址中.
这种算法被称为hash算法, 所以, 切记, 在dict中存储的key-value中的key'必须是可hash的,
如果你搞不懂什什么是可哈希, 暂时可以这样记, 可以改变的都是不可哈希的,
那么可哈希就意味着不可变. 这个是为了了能准确的计算内存地址⽽而规定的.
已知的可哈希(不可变)的数据类型: int, str, tuple, bool
不可哈希(可变)的数据类型: list, dict, set
语法 :
{key1: value1, key2: value2....}
注意: key必须是不可变(可哈希)的. value没有要求.可以保存任意类型的数据
dict保存的数据不是按照我们添加进去的顺序保存的. 是按照hash表的顺序保存的. ⽽而hash表
不是连续的. 所以不能进⾏行行切片⼯工作. 它只能通过key来获取dict中的数据
增
删
改
查
其他
嵌套
'''
# 合法
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)])
# dict保存的数据不是按照我们添加进去的顺序保存的. 是按照hash表的顺序保存的. ⽽而hash表
# 不是连续的. 所以不能进⾏行行切片⼯工作. 它只能通过key来获取dict中的数据
# 不不合法
# dic = {[1, 2, 3]: '周杰伦'} # list是可变的. 不不能作为key
# dic = {{1: 2}: "哈哈哈"} # dict是可变的. 不不能作为key
# dic = {{1, 2, 3}: '呵呵呵'} # set是可变的, 不不能作为key
# 1. 增加
dic = {}
dic['name'] = '周润发' # 如果dict中没有出现这个key, 就会新增⼀一个key-value的组合进dict
dic['age'] = 18
print(dic)
# 如果dict中没有出现过这个key-value. 可以通过setdefault设置默认值
dic.setdefault('李李嘉诚') # 也可以往⾥里里⾯面设置值.
dic.setdefault("李李嘉诚", "房地产") # 如果dict中已经存在了了. 那么setdefault将不不会起作⽤用
print(dic)
print('--------------------------------------------------------')
# 2. 删除
ret = dic.pop("age")
print(ret)
print('--------------------------------------------------------')
del dic["name"]
print(dic)
print('--------------------------------------------------------')
# 随机删除.
ret = dic.popitem()
# 清空字典中的所有内容
dic.clear()
print('--------------------------------------------------------')
# 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)
print('--------------------------------------------------------')
# 4. 查询
# 查询⼀一般⽤用key来查找具体的数据.
print(dic['name'])
# print(dic['sylar']) # 报错
print(dic.get("ok"))
print(dic.get("sylar")) # None
print(dic.get("sylar", "⽜牛B")) # ⽜牛B
print('--------------------------------------------------------')
# 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('--------------------------------------------------------')
print(dic.values()) # dict_values([123, 'sylar', 18, '科⽐比']) ⼀一样. 也当list来⽤用
for value in dic.values():
print(value)
print('--------------------------------------------------------')
print(dic.items()) # dict_items([('id', 123), ('name', 'sylar'), ('age',18), ('ok', '科⽐比')]) 这个东⻄西也是list. 只不不过list中装的是tuple
for key, value in dic.items(): # ?? 这个是解构
print(key, value)
print('--------------------------------------------------------')
# 解构
a, b = 1, 2
print(a, b)
(c, d) = 3, 4
print(c, d)
# e, f = [1, 2, 3] # 解构的时候注意数量量必须匹配
# print(e, f)
print('--------------------------------------------------------')
# 三. 字典的嵌套
# 字典的嵌套
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])
dic1 = {
'name':['alex',2,3,5],
'job':'teacher',
'oldboy':{'alex':['python1','python2',100]}
}
'''
1,将name对应的列列表追加⼀一个元素’wusir’。
2,将name对应的列列表中的alex首字母⼤大写。
3,oldboy对应的字典加⼀一个键值对’⽼老老男孩’,’linux’。
4,将oldboy对应的字典中的alex对应的列列表中的python2删除。
'''
dic1.get("name").append("wusir")
print(dic1)
print('--------------------------------------------------------')
s = dic1.get("name")[0]
s = s.capitalize()
dic1.get("name")[0] = s
print(dic1)
print('--------------------------------------------------------')
temp = {'老男孩':'linux'}
dic1.get("oldboy").update(temp)
print(dic1)
print('--------------------------------------------------------')
dic1.get("oldboy").get("alex").remove("python2")
print(dic1)
三.setdefault说明
setdefault函数的用法及理解
dict.setdefault(key, default=None)
功能:
如果键不存在于字典中,将会添加该键并将default的值设为该键的默认值,如果键存在于字典中,将读出该键原来对应的值,default的值不会覆盖原来已经存在的键的值。
参数:
key—-要查找的键
default—–查找的键不存在时用于设置的默认值
>>> ExsampleDict={"Exist":"Elle"}
>>> Res=ExsampleDict.setdefault("NotExist",)
>>> print ExsampleDict
{'NotExist': None, 'Exist': 'Elle'}
>>> ExsampleDict={"Exist":"Elle"}
>>> Res=ExsampleDict.setdefault("NotExist","Replace")
>>> print Res
Replace
>>> type(Res)
<type 'str'>
>>> print ExsampleDict
{'NotExist': 'Replace', 'Exist': 'Elle'}
例题:
li= [11,22,33,44,55,66,77,88,99,90]
dic = {'k1':[],'k2':[]}
for i in li:
if i == 66:
continue
elif i > 66:
dic.setdefault('k1').append(i) # dict中已经存在K1, 所以默认值None,不会代替已有的值, 而后面有append 会执行添加操作
else:
dic.setdefault('k2').append(i)
print(dic)