Python基础知识之2——字典

  字典是什么?

字典是另外一个可变的数据结构,且可存储任意类型对象,比如字符串、数字、列表等。字典是由关键字两部分组成,也就是 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(['杨幂'],{'名字':'扶摇','喜欢的男角色':['长孙无极','战北野','小七'],'去过的国家':['太渊','天权','天煞','璇玑']})