字典是什么?
字典是另外一个可变的数据结构,且可存储任意类型对象,比如字符串、数字、列表等。字典是由关键字和值两部分组成,也就是 key 和 value,中间用冒号分隔。这种结构类似于新华字典,字典中每一个字都有一个对应的解释,具体的用法是这样的:
字典名 = {关键字1:值,关键字2:值,关键字3:值}
注:
1)键是唯一的,创建第二个同名键的时候,第二个同名键会覆盖第一个同名键,即不允许出现两个相同的键;
2)键是不可变的,不能用列表当键。
eg:
# 构建一个字典,记录各个教师的收入 name_money = {'王老师':30000,'侯老师':28000,'李老师':33000,'张老师':25000} print(name_money) print('字典的数据类型表示是:',type(name_money))
结果是:
{'王老师': 30000, '侯老师': 28000, '李老师': 33000, '张老师': 25000} 字典的数据类型表示是: <class 'dict'>
字典的基本操作:
常见的字典操作是访问字典、遍历字典等,实际项目中经常被使用到,比如 excel 文件读入内存以后,按照字典的方法存放,然后对其增删值。
访问字典:
访问字典也就是获取关键字对应的值,方法是指定字典名和放在方括号内的关键字,获取后的值可以赋值给变量。
eg:
Teacher_Li = name_money['李老师'] print(f'李老师的月薪是:{Teacher_Li}元/月')
结果是:
李老师的月薪是:33000元/月
添加、修改、删除键值对:
字典是一种可变的数据结构,可以随时添加或者删除其中的键值对。方法是,指定字典名、用方括号括起的键和相关的值。
eg:
print(f'原来老师们的月薪情况是:{name_money}') # 新来了熊老师和陈老师,他们的月薪如下: name_money['熊老师'] = 15000 name_money['陈老师'] = 50000 print(f'新来老师后,老师们的月薪情况是:{name_money}') # 熊老师因为研究突破,所以工资涨了5000块,变成了20000 name_money['熊老师'] = 15000 + 5000 print(f'熊老师加薪后,老师们的月薪情况是:{name_money}') # 李老师因为个人原因,离开了学校 del name_money['李老师'] print(f'李老师走后,老师们的月薪情况是:{name_money}')
结果是:
原来老师们的月薪情况是:{'王老师': 30000, '侯老师': 28000, '李老师': 33000, '张老师': 25000} 新来老师后,老师们的月薪情况是:{'王老师': 30000, '侯老师': 28000, '李老师': 33000, '张老师': 25000, '熊老师': 15000, '陈老师': 50000} 熊老师加薪后,老师们的月薪情况是:{'王老师': 30000, '侯老师': 28000, '李老师': 33000, '张老师': 25000, '熊老师': 20000, '陈老师': 50000} 李老师走后,老师们的月薪情况是:{'王老师': 30000, '侯老师': 28000, '张老师': 25000, '熊老师': 20000, '陈老师': 50000}
创建空字典:
在实际项目中,我们可能不知道字典中存放的内容是什么。这时,我们可以采用从空的字典开始动态创建,也就是在程序运行的时候添加具体的内容。
常见的使用场景是:第一个:需要用户输入数据存储为字典;第二个是自动生成大量的键值对,比如爬虫,爬取豆瓣电影的排名信息。我们可以把排名放入空的字典中,然后每次爬取一个电影, 添加一个对应的键值对。
# 从空的字典开始创建 student_info = {} # 定义空的字典 student_info['姓名'] = '胡晓明' student_info['学号'] = 201811131123 student_info['专业'] = '信息与科学技术' student_info['班级'] = '一班' print('从空的列表中构建字典:',student_info)
结果是:
从空的列表中构建字典: {'姓名': '胡晓明', '学号': 201811131123, '专业': '信息与科学技术', '班级': '一班'}
字典的内置函数
# 内置函数
# 内置函数cmp()的替代方法
import operator as op op.lt('王老师','刘老师') # 相当与'王老师'<'张老师' op.le('王老师','张老师') # 相当于'王老师'<='张老师' op.eq('王老师','张老师') # 相当于'王老师'=='张老师' op.ne('王老师','张老师') # 相当于'王老师'!='张老师' op.gt('王老师','张老师') # 相当于'王老师'>'张老师' op.ge('王老师','张老师') # 相当于 '王老师'>='张老师' # 计算字典元素个数,即键的总数。 len(name_money) # 输出字典可打印的字符串表示。 str(name_money) # 内置方法 name_money1 = name_money.copy() # 复制字典 name_money1.clear() # 删除字典 name_money1['刘老师'] = 32000 name_money.fromkeys([1,3,4],'谁') # 创建一个新字典,其中前一个参数序列为键,后一个参数为值,适用于批量产生多个同值得键 name_money.get('王老师',None) # 获取对应键的值,如果没有该键,则返回参数2 name_money.setdefault('张老师', None) #获取对应键的值,如果没有该键,则在原字典里添加上该键值对,值为参数2 '熊老师' in name_money # 判断键是否在字典中 name_money.items() # 元组形式存储字典 name_money.keys() # 返回所有的键 name_money.values() # 返回所有的值 name_money.update(name_money1) # 合并两个字典的键值对
字典与列表结合:
把一系列字典存储在列表中,或将列表作为值放在字典中,这称为嵌套。你可以在列表中嵌套字典、在字典中嵌套列表甚至在字典中嵌套字典。这在项目中经常用到。
什么时候用列表什么时候用字典呢?
当你存取的数据类型一样时,使用列表,当你存取的数据类型不一样时就用字典。
注:数据类型不一样不是指整形或者字符型。
举个例子:如果你需要存很多人的姓名,仅仅这一个属性,就用列表来进行处理,当你要存取不仅仅是人名,包括年龄,性别,国籍等等这些信息时,这时候用字典是最合适的。
字典列表
# 合并两个字典,每个字典存为一个元素 la = [name_money1,name_money]
在字典中存储列表
# 在字典中存放列表 family = {'小米':['小米8','小米note'],'华为':['华为P20','荣耀9'],'苹果':['iphone8','iphoneX']} print(family) # 上述代码的运行结果是: # {'小米': ['小米8', '小米note'], '华为': ['华为P20', '荣耀9'], '苹果': ['iphone8', 'iphoneX']}
在字典中存储字典
# 在字典中存储字典 phone = {'小米':{'小米8':3000,'小米note':5000},'华为':{'华为P20':3300,'荣耀9':2055},'苹果':{'iphone8':8000,'iphoneX':12000}} print(phone) # 找出虾米 print(phone['小米']['小米8']) # 以上代码输出的结果是: # {'小米': {'小米8': 3000, '小米note': 5000}, '华为': {'华为P20': 3300, '荣耀9': 2055}, '苹果': {'iphone8': 8000, 'iphoneX': 12000}} # 3000
小小的项目练习
# 《扶摇》演员表的小练习 # 创建一个字典存放演员信息 Fuyao_Actor_Profile = {'杨幂':{'角色':'扶摇','配音演员':'王潇倩'},'阮经天':{'角色':'长孙无极','配音演员':'马正阳'},'刘奕君':{'角色':'齐震','配音演员':'刘奕君'},'高伟光':{'角色':'战北野','配音演员':'赵成晨'},'王劲松':{'角色':'长孙迥','配音演员':'王劲松'},'黄宥明':{'角色':'燕惊尘','配音演员':'文森'},'高瀚宇':{'角色':'江枫','配音演员':'袁聪宇'},'顾又铭':{'角色':'战北恒','配音演员':'林强'},'秦焰':{'角色':'周叔','配音演员':'宣晓鸣'},'蒋龙':{'角色':'小七','配音演员':'苏尚卿'}} # 打印出杨幂扮演的角色 print(f'杨幂扮演的角色是:{Fuyao_Actor_Profile["杨幂"]["角色"]}') # 创建一个备份字典,备份演员信息表 Copy_Fuyao = Fuyao_Actor_Profile.copy() # 删去阮经天的演员表 del Fuyao_Actor_Profile['阮经天'] print(f'删去阮经天后的演员表为:{Fuyao_Actor_Profile}') # 更换为演员陈晓 Fuyao_Actor_Profile['陈晓'] = {'角色':'长孙无极','配音演员':'马正阳'} print(f'阮经天换为陈晓后的演员表为:{Fuyao_Actor_Profile}') # 新增加角色 Fuyao_Actor_Profile['张雅钦'] = {'角色':'雅兰珠','配音演员':'吟良犬'} Fuyao_Actor_Profile['王鹤润'] = {'角色':'凤净梵','配音演员':'蔡娜'} Fuyao_Actor_Profile['周俐葳'] = {'角色':'时岚','配音演员':'张晗'} Fuyao_Actor_Profile['魏晖倪'] = {'角色':'简雪','配音演员':'曹一茜'} # 打印出阮经天所在的演员表里的演员名 print(f'阮经天所在的演员表里的演员名:{Copy_Fuyao.keys()}') # 打印出阮经天所在的演员表里的角色名,并统计一共有多少个演员 print('阮经天所在的演员表里的角色名:') for i in Copy_Fuyao.keys(): print(f'{Copy_Fuyao[i]["角色"]}') print(f'一共有{len(Copy_Fuyao)}个角色') # 扶摇的详细细节 Fuyao_Actor_Profile.fromkeys(['杨幂'],{'名字':'扶摇','喜欢的男角色':['长孙无极','战北野','小七'],'去过的国家':['太渊','天权','天煞','璇玑']})