字典
什么是字典(dict)
字典是容器型数据类型;将{}作为容器的标志,里面的元素用逗号隔开,元素必须是键值对:{键1:值1, 键2:值2…}
字典是可变的(支持增删改);字典是无序的(不支持下标操作)
元素的要求:
a.键:键必须是不可变数据类型的数据(一般是字符串);键是唯一的
b.值:没有要求
空字典
dict1 = {}
字典是无序的
print({'a': 10, 'b': 20} == {'b': 20, 'a': 10}) # True
字典的键是不可变的数据
dict2 = {10: 20, 1.2: 30}
键是唯一的
dict4 = {'a': 10, 'a': 100}
print(dict4) # {'a': 100}
字典的查操作
1.查单个 - 获取单个值
语法1:字典[键] - 获取指定键相应的值,键如果不存在会报错
语法2:字典.get(键) - 获取指定键相应的值,键如果不存在不报错返回空值
语法3:字典.get(键,默认值) -获取指定键相应的值,键如果不存在返回默认值
示例:
dog = {'name': 'cc', 'gender': '母', 'breed': '哈士奇', 'age': 3}
print(dog['name']) # cc
a = dog.get('age')
print(a) # 3
# print(dog['price']) # 报错
print(dog.get('price')) # None
print(dog.get('price', 3333)) # 3333
# 练习:创建一个字典保存一个班级的信息
class1 = {
'name': 'Python2202',
'address': '14教室',
'lecturer': {'name': '余婷', 'qq': '726550822', 'gender': '女', 'age': 18},
'head_teacher': {'name': '舒玲', 'tel': '110', 'gender': '女', 'age': 18},
'students': [
{'name': 'stu0', 'tel': '120', 'gender': '男', 'major': '软件工程', 'age': 20,
'linkman': {'name': 'p1', 'tel': '29372'}},
{'name': 'stu1', 'tel': '62736', 'gender': '女', 'major': '电子信息', 'age': 23,
'linkman': {'name': 'p2', 'tel': '78221'}},
{'name': 'stu2', 'tel': '1292831', 'gender': '女', 'major': '会计', 'age': 27,
'linkman': {'name': 'p3', 'tel': '28239'}},
{'name': 'stu3', 'tel': '72289392', 'gender': '男', 'major': '数学', 'age': 21,
'linkman': {'name': 'p4', 'tel': '29102'}},
{'name': 'stu4', 'tel': '2737288', 'gender': '女', 'major': '计算机', 'age': 32,
'linkman': {'name': 'p5', 'tel': '236721'}},
{'name': 'stu5', 'tel': '27361028', 'gender': '男', 'major': '物理', 'age': 19,
'linkman': {'name': 'p6', 'tel': '34293'}},
{'name': 'stu6', 'tel': '829129', 'gender': '男', 'major': '石油', 'age': 22,
'linkman': {'name': 'p7', 'tel': '229311'}}
]
}
# 1. 获取班级名
# 2. 获取讲师的名字
# 3. 获取班主任的电话
# 4. 打印所有学生的名字
# 5. 统计学生中男生的个数
# 6. 计算班级学生的平均年龄
# 7. 打印所有学生的联系人的电话号码
print(class1['name'])
print(class1['lecturer']['name'])
print(class1['head_teacher']['tel'])
a = class1.get('students')
print(a)
for i in range(len(a)):
print(a[i].get('name'))
s = 0
for i in range(len(a)):
if a[i].get('gender') == '男':
s += 1
print(s)
avg = 0
for i in range(len(a)):
avg += a[i].get('age')
print(avg / len(a))
a = class1.get('students')
for i in range(len(a)):
b = a[i].get('linkman')
print(b.get('tel'))
遍历
for 变量 in 字典:
循环体
注意:变量依次获取到的是字典所有的键
示例:
dog = {'name': 'cc', 'gender': '母', 'breed': '哈士奇', 'age': 3}
for x in dog:
print(x, dog[x])
字典的增删改
增、删
语法1:字典[键] = 值 - 如果键不存在就添加键值对,如果键存在就修改指定键对应的值
语法2:字典.setdefault(键,值) - 添加键值对(键不存在会添加,键如果存在不会修改)
示例:
goods = {'name': '老坛酸菜牛肉面', 'price': 3.5, 'weight': 300}
goods['shelf_life'] = 30
print(goods) # {'name': '老坛酸菜牛肉面', 'price': 3.5, 'weight': 300, 'shelf_life': 30}
goods['price'] = 3
print(goods) # {'name': '老坛酸菜牛肉面', 'price': 3, 'weight': 300, 'shelf_life': 30}
goods = {'name': '老坛酸菜牛肉面', 'price': 3.5, 'weight': 300}
goods.setdefault('count', 100)
print(goods) # {'name': '老坛酸菜牛肉面', 'price': 3.5, 'weight': 300, 'count': 100}
goods.setdefault('price', 3)
print(goods) # {'name': '老坛酸菜牛肉面', 'price': 3.5, 'weight': 300, 'count': 100}
print('-------------------------------------------')
# 练习:将没有折扣的商品的discount的值都设置成1
goods_list = [
{'name': '老坛酸菜泡面', 'price': 3.5, 'weight': 300, 'discount': 0.8},
{'name': '牛奶', 'price': 5, 'weight': 250},
{'name': '火腿肠', 'price': 1.5, 'weight': 100},
{'name': '可乐', 'price': 9, 'weight': 800, 'discount': 0.95}
]
for x in goods_list:
x.setdefault('discount', 1)
print(goods_list)
删
1.del 字典[键] - 删除指定键对应的键值对
2.字典.pop(键) - 取出指定键对应的值
示例:
dog = {'name': 'cc', 'gender': '母', 'breed': '哈士奇', 'age': 3}
print(dog)
del dog['breed']
print(dog) # {'name': 'cc', 'gender': '母', 'age': 3}
print('---------------------分割线--------------------------')
dog = {'name': 'cc', 'gender': '母', 'breed': '哈士奇', 'age': 3}
dog.pop('age')
print(dog) # {'name': 'cc', 'gender': '母', 'breed': '哈士奇'}
字典相关操作、函数和方法
字典相关操作: in 和 not in
字典不支持+、*、比较大小
字典的in 和 not in 判断的是是否存在指定的键
print(10 in {'a': 10}) # False
print('a' in {'a': 10}) # True
字典相关函数:len、dict
补充:字典转化成列表的时候,是将字典的键作为列表的元素
对数据的要求:a.数据本身是一个序列
b.序列中的元素必须是有两个元素的小序列
c.小序列的第一个元素是不可变的类型的数据
示例:
dict1 = {'a': 10, 'b': 20}
print(list(dict1)) # ['a', 'b']
print(dict([['a', 10], ['b', 20]])) # {'a': 10, 'b': 20}
print(dict(['ab', 'cd'])) # {'a': 'b', 'c': 'd'}
print(dict(['ab', (10, 20), ['age', 18], range(2)])) # {'a': 'b', 10: 20, 'age': 18, 0: 1}
字典相关方法:字典.方法()
字典.clear() - 清空字典
字典.copy() - 拷贝原字典产生一个一模一样的新字典
字典.get()
字典.keys() - 获取所有的键
字典.values() - 获取所有的值
字典.items() - 以元组的形式返回键值对
字典1.update(字典2) - 将字典2中所有的键值对都添加到字典1
示例:
dog = {'name': 'cc', 'gender': '母', 'breed': '哈士奇', 'age': 3}
print(dog.keys()) # dict_keys(['name', 'gender', 'breed', 'age'])
print(dog.values()) # dict_values(['cc', '母', '哈士奇', 3])
print(dog.items()) # dict_items([('name', 'cc'), ('gender', '母'), ('breed', '哈士奇'), ('age', 3)])
print('---------------------分割线--------------------------')
for key, value in dog.items():
print(key, value)
dict1 = {'a': 10, 'b': 20, 'c': 30}
dict1.update({'name': '张三', 'age': 18})
print(dict1) # {'a': 10, 'b': 20, 'c': 30, 'name': '张三', 'age': 18}
字典推导式
结构1:{表达式1:表达式2 for 变量 in 序列}
结构2:{表达式1:表达式2 for 变量 in 序列 if 条件语句}
示例:
print({x: x * 2 for x in range(4)}) # {0: 0, 1: 2, 2: 4, 3: 6}
# 练习: 交换字典中所有的键值对键和值的位置
dict1 = {'a': 10, 'b': 20, 'c': 30}
print({x: y for y, x in dict1.items()}) # {10: 'a', 20: 'b', 30: 'c'}
练习
- 定义一个变量保存一个学生的信息,学生信心中包括:姓名、年龄、成绩(单科)、电话、性别
students = {'name': '张三', 'age': 18, 'math_garde': 90, 'en_garde': 85, 'tel': '123123', 'gender': '男'}
- 定义一个列表,在列表中保存6个学生的信息(学生信息中包括: 姓名、年龄、成绩(单科)、电话、性别(男、女、不明) )
- 统计不及格学生的个数
- 打印不及格未成年学生的名字和对应的成绩
- 求所有男生的平均年龄
- 打印手机尾号是8的学生的名字
- 打印最高分和对应的学生的名字
- 删除性别不明的所有学生
- 将列表按学生成绩从大到小排序(挣扎一下,不行就放弃)
students =[{'name': '张三', 'age': 18, 'math_garde': 90, 'tel': 1231233, 'gender': '男'},
{'name': '李四', 'age': 17, 'math_garde': 35, 'tel': 1231258, 'gender': '女'},
{'name': '小云', 'age': 16, 'math_garde': 54, 'tel': 12312443, 'gender': '男'},
{'name': '王五', 'age': 15, 'math_garde': 55, 'tel': 1231228, 'gender': '女'},
{'name': '赵六', 'age': 18, 'math_garde': 65, 'tel': 1231213, 'gender': '男'},
{'name': '小何', 'age': 18, 'math_garde': 82, 'tel': 12312323, 'gender': '不明'}]
#1
count = 0
for i in students:
if i['math_garde'] < 60:
count += 1
print(count)
students =[{'name': '张三', 'age': 18, 'math_garde': 90, 'tel': 1231233, 'gender': '男'},
{'name': '李四', 'age': 17, 'math_garde': 35, 'tel': 1231258, 'gender': '女'},
{'name': '小云', 'age': 16, 'math_garde': 54, 'tel': 12312443, 'gender': '男'},
{'name': '王五', 'age': 15, 'math_garde': 55, 'tel': 1231228, 'gender': '女'},
{'name': '赵六', 'age': 18, 'math_garde': 65, 'tel': 1231213, 'gender': '男'},
{'name': '小何', 'age': 18, 'math_garde': 82, 'tel': 12312323, 'gender': '不明'}]
#2
for i in students:
if i['math_garde'] < 60 and i['age'] < 18:
print(i['name'])
#3
students =[{'name': '张三', 'age': 18, 'math_garde': 90, 'tel': 1231233, 'gender': '男'},
{'name': '李四', 'age': 17, 'math_garde': 35, 'tel': 1231258, 'gender': '女'},
{'name': '小云', 'age': 16, 'math_garde': 54, 'tel': 12312443, 'gender': '男'},
{'name': '王五', 'age': 15, 'math_garde': 55, 'tel': 1231228, 'gender': '女'},
{'name': '赵六', 'age': 18, 'math_garde': 65, 'tel': 1231213, 'gender': '男'},
{'name': '小何', 'age': 18, 'math_garde': 82, 'tel': 12312323, 'gender': '不明'}]
s = 0
count = 0
for i in students:
if i['gender'] == '男':
s += i['age']
count += 1
print(s / count)
#4
students =[{'name': '张三', 'age': 18, 'math_garde': 90, 'tel': 1231233, 'gender': '男'},
{'name': '李四', 'age': 17, 'math_garde': 35, 'tel': 1231258, 'gender': '女'},
{'name': '小云', 'age': 16, 'math_garde': 54, 'tel': 12312443, 'gender': '男'},
{'name': '王五', 'age': 15, 'math_garde': 55, 'tel': 1231228, 'gender': '女'},
{'name': '赵六', 'age': 18, 'math_garde': 65, 'tel': 1231213, 'gender': '男'},
{'name': '小何', 'age': 18, 'math_garde': 82, 'tel': 12312323, 'gender': '不明'}]
for i in students:
if i['tel'] % 10 == 8:
print(i['name'])
#5
students =[{'name': '张三', 'age': 18, 'math_garde': 90, 'tel': 1231233, 'gender': '男'},
{'name': '李四', 'age': 17, 'math_garde': 35, 'tel': 1231258, 'gender': '女'},
{'name': '小云', 'age': 16, 'math_garde': 54, 'tel': 12312443, 'gender': '男'},
{'name': '王五', 'age': 15, 'math_garde': 55, 'tel': 1231228, 'gender': '女'},
{'name': '赵六', 'age': 18, 'math_garde': 90, 'tel': 1231213, 'gender': '男'},
{'name': '小何', 'age': 18, 'math_garde': 90, 'tel': 12312323, 'gender': '不明'}]
garde = []
for i in students:
a = i.get('math_garde')
garde.append(a)
index1 = (garde.index(max(garde)))
for i in (range(len(students))):
if students[i]['math_garde'] == max(garde) and i != index1:
print('math:',students[i]['name'])
print('math:',students[index1]['name'])
# 6
students =[{'name': '张三', 'age': 18, 'math_garde': 90, 'tel': 1231233, 'gender': '男'},
{'name': '李四', 'age': 17, 'math_garde': 35, 'tel': 1231258, 'gender': '女'},
{'name': '小云', 'age': 16, 'math_garde': 54, 'tel': 12312443, 'gender': '男'},
{'name': '王五', 'age': 15, 'math_garde': 55, 'tel': 1231228, 'gender': '女'},
{'name': '赵六', 'age': 18, 'math_garde': 65, 'tel': 1231213, 'gender': '男'},
{'name': '小何', 'age': 18, 'math_garde': 82, 'tel': 12312323, 'gender': '不明'}]
print([x for x in students if x['gender'] != '不明'])
# 7
students =[{'name': '张三', 'age': 18, 'math_garde': 90, 'tel': 1231233, 'gender': '男'},
{'name': '李四', 'age': 17, 'math_garde': 35, 'tel': 1231258, 'gender': '女'},
{'name': '小云', 'age': 16, 'math_garde': 54, 'tel': 12312443, 'gender': '男'},
{'name': '王五', 'age': 15, 'math_garde': 55, 'tel': 1231228, 'gender': '女'},
{'name': '赵六', 'age': 18, 'math_garde': 65, 'tel': 1231213, 'gender': '男'},
{'name': '小何', 'age': 18, 'math_garde': 82, 'tel': 12312323, 'gender': '不明'}]
print('---------------------分割线--------------------------')
garde = []
new_students = []
for i in students:
a = i.get('math_garde')
garde.append(a)
for i in range (len(students)):
index1 = (garde.index(max(garde)))
garde.remove(max(garde))
new_students.append(students[index1])
print(students[index1])
print('---------------------分割线--------------------------')
print(new_students)
- 定义一个变量保存一个班级的信息,班级信息中包括:班级名称、教室位置、班主任信息、讲师信息、班级所有的学生(根据实际情况确定数据类型和具体信息)
class1 = {
'name': 'Python2202',
'address': '14教室',
'lecturer': {'name': '余婷', 'qq': '726550822', 'gender': '女', 'age': 18},
'head_teacher': {'name': '舒玲', 'tel': '110', 'gender': '女', 'age': 18},
'students': [
{'name': 'stu0', 'tel': '120', 'gender': '男', 'major': '软件工程', 'age': 20,
'linkman': {'name': 'p1', 'tel': '29372'}},
{'name': 'stu1', 'tel': '62736', 'gender': '女', 'major': '电子信息', 'age': 23,
'linkman': {'name': 'p2', 'tel': '78221'}},
{'name': 'stu2', 'tel': '1292831', 'gender': '女', 'major': '会计', 'age': 27,
'linkman': {'name': 'p3', 'tel': '28239'}},
{'name': 'stu3', 'tel': '72289392', 'gender': '男', 'major': '数学', 'age': 21,
'linkman': {'name': 'p4', 'tel': '29102'}},
{'name': 'stu4', 'tel': '2737288', 'gender': '女', 'major': '计算机', 'age': 32,
'linkman': {'name': 'p5', 'tel': '236721'}},
{'name': 'stu5', 'tel': '27361028', 'gender': '男', 'major': '物理', 'age': 19,
'linkman': {'name': 'p6', 'tel': '34293'}},
{'name': 'stu6', 'tel': '829129', 'gender': '男', 'major': '石油', 'age': 22,
'linkman': {'name': 'p7', 'tel': '229311'}}
]
}
- 已知一个列表保存了多个狗对应的字典:
dogs = [
{'name': '贝贝', 'color': '白色', 'breed': '银狐', 'age': 3, 'gender': '母'},
{'name': '花花', 'color': '灰色', 'breed': '法斗', 'age': 2},
{'name': '财财', 'color': '黑色', 'breed': '土狗', 'age': 5, 'gender': '公'},
{'name': '包子', 'color': '黄色', 'breed': '哈士奇', 'age': 1},
{'name': '可乐', 'color': '白色', 'breed': '银狐', 'age': 2},
{'name': '旺财', 'color': '黄色', 'breed': '土狗', 'age': 2, 'gender': '母'}
]
- 利用列表推导式获取所有狗的品种
[‘银狐’, ‘法斗’, ‘土狗’, ‘哈士奇’, ‘银狐’, ‘土狗’]
new = [i.get('breed') for i in dogs]
print(new)
- 利用列表推导式获取所有白色狗的名字
[‘贝贝’, ‘可乐’]
new = [i.get('name') for i in dogs if i.get('color') == '白色']
print(new)
- 给dogs中没有性别的狗添加性别为 ‘公’
for i in dogs:
i.setdefault('gender','公')
print(dogs)
- 统计 ‘银狐’ 的数量
count = 0
for i in dogs:
if i.get('breed') == '银狐':
count += 1
print(count)