- 字典
- 字典的定义
- 字典的原理
- 字典的创建
- 字典元素的常用 *** 作
- 字典中元素的获取
- key的判断
- 字典元素的删除
- 字典元素的新增
- 获取字典视图的三个方法
- 字典元素的遍历
- 字典的特点
- 字典生成式
- 总结
- Python内置的数据结构之一,与列表一样是一个可变序列(可以进行增删改 *** 作)
- 以‘键值对’的方式存储数据,字典是一个‘无序的序列’
scores={'张三':100,'李四':98,'王五':45} #三个键值对
# scores--->字典名 '张三'--->键 冒号 100--->值
字典的原理
字典的实现原理:字典的实现原理与查字典类似,查字典是先根据部首或拼音查找汉字对应的页码,Python中的字典是通过hash函数计算key查找value所在的位置。
注意:key一定是不可变序列(不可以执行增删改 *** 作)——字符串str、整数序列range。
可变序列(可以执行增删改 *** 作)——字典、列表
字典创建方法:
- 最常用的方式:使用花括号{}
ex:scores={‘张三’:100,‘李四’:98,‘王五’:45}- 使用内置函数dict()
ex:dict(name=‘jack’,age=20)
#使用{}创建字典
scores={'张三':100,'李四':98,'王五':45}
print(scores) # {'张三': 100, '李四': 98, '王五': 45}
print(type(scores)) #
#使用dict()创建字典
student=dict(name='Jack',age=20)
print(student) # {'name': 'Jack', 'age': 20}
#创建空字典
d={}
print(d) # {}
字典元素的常用 *** 作
字典中元素的获取
[]
取值——ex:scores[‘张三’]get()
方法取值——ex:scores.get(‘张三’)
[]
取值与get()
取值区别:
[]
如果字典中不存在指定的key,抛出keyerror异常get()
方法取值,如果字典中不存在指定的key,并不会抛出keyerror,而是返回None;可以通过参数设置默认的value,以便指定的key不存在时返回
scores={'张三':100,'李四':98,'王五':45}
# 第一种方式:使用[]
print(scores['张三']) # 100
#print(scores['陈六']) #报错 KeyError: '陈六'
# 第二种方式:使用get()
print(scores.get('张三')) # 100
print(scores.get('陈六')) # None
print(scores.get('麻七',99)) # 99 99是在查找'麻七'所对应的value不存在时,提供的一个默认值
key的判断
- in——>指定的key在字典中存在返回True——>‘张三’ in scores
- not in——>指定的key在字典中不存在返回True——>‘Marry not in scores’
scores={'张三':100,'李四':98,'王五':45}
print('张三' in scores) #True
print('张三' not in scores) #False
字典元素的删除
del scores[‘张三’]——删除指定的 key-value 对
scores.clear()——清空字典的元素
scores={'张三':100,'李四':98,'王五':45}
del scores['张三']
print(scores) # {'李四': 98, '王五': 45}
scores.clear() #清空字典的元素
print(scores) #{}
字典元素的新增
scores[‘jack’]=90
scores={'张三':100,'李四':98,'王五':45}
scores['陈六']=88
print(scores) #{'李四': 98, '王五': 45, '陈六': 88}
#进行修改
scores['陈六']=100
print(scores) #{'李四': 98, '王五': 45, '陈六': 100}
获取字典视图的三个方法
- keys()—>获取字典中所有key
- values()—>获取所有value
- items()—>获取所有key,value对
scores={'张三':100,'李四':98,'王五':45}
# 获取所有的key
keys=scores.keys()
print(keys) # dict_keys(['张三', '李四', '王五'])
print(type(keys)) #
print(list(keys)) # 将所有key组成的视图转成列表 ['张三', '李四', '王五']
# 获取所有value
values=scores.values()
print(values) # dict_values([100, 98, 45])
print(type(values)) #
print(list(values)) # [100, 98, 45]
#获取所有key-value对
items=scores.items()
print(items) # dict_items([('张三', 100), ('李四', 98), ('王五', 45)])
print(type(items)) #
print(list(items)) # 转换之后的列表元素是由元组()组成的 [('张三', 100), ('李四', 98), ('王五', 45)]
字典元素的遍历
for item in scores :
print (item)
scores={'张三':100,'李四':98,'王五':45}
for item in scores:
print(item,scores[item],scores.get(item))
输出:
张三 100 100
李四 98 98
王五 45 45
字典的特点
- 字典中的所有元素都是一个 key-value 对,key不允许重复(一旦重复,前面的value会被覆盖),value可以重复
- 字典中的所有元素是无序的
- 字典中的 key 必须是不可变对象—— str 整数
- 字典也可以根据需要动态的伸缩
- 字典会浪费较大的内存,是一种使用空间换时间的数据结构
# key 不允许重复
d={'name':'张三' , 'name':'李四'}
print(d) #{'name': '李四'}
# value可以重复
d={'name':'张三','nikename':'张三'}
print(d) #{'name': '张三', 'nikename': '张三'}
#如果字典的key是可变对象list,则会报错
lst=[10,100,60]
d={lst:100}
print(d) # TypeError: unhashable type: 'list'
字典生成式
内置函数zip()
——用于将’可迭代对象’作为参数,将对象中对应的元素打包成一个元组,然后返回由这些元组组成的列表
{表示字典key的表达式 : 表示字典value的表达式
for
自定义表示key的变量, 自定义表示value的变量in zip( , )
}
zip()
——可迭代对象
items=['Fruits','Books','Others']
prices=['96','78','85']
d={item.upper():price for item, price in zip(items,prices)}
print(d) #{'FRUITS': '96', 'BOOKS': '78', 'OTHERS': '85'}
#upper()---将items中所有字母变大写
总结
- 字典的创建
a. 使用{} 花括号
b. 内置函数dict()
c. 字典生成式- 常用 *** 作
a. 获取value
1)字典名[key]
2)字典名.get(key)
b. 删除key-value对
1)del 字典名[key]
c. 修改\新增
1)字典名[key]=value
d. in \ not in 判断- 获取视图的三个方法
a. keys()—>获取字典中所有key
b. values()—>获取所有value
c. items()—>获取所有key,value对- 字典生成式
{表示字典key的表达式 : 表示字典value的表达式 for自定义表示key的变量, 自定义表示value的变量 in zip( , )}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)