day 7 学习笔记
认识字典
(1)字典是容器型数据类型
(2)字典是可变的(支持增删改);字典是无序的(不支持下标操作)
(3) 元素的要求:
a. 键:键必须是不可变的数据类型的数据;键是唯一的
b. 值:没有要求
字典的查操作
(1)查单个
字典[键]
字典.get(键)
字典.get(键, 默认值)
(2) 遍历
for 变量 in 字典:
循环体
字典的增删改操作
1.增、改
语法1:字典[键] = 值 - 如果键不存在就添加键值对;如果键存在就修改指定键对应的值
语法2:字典.setdefault(键, 值) - 增加键值对
2.删除
(1)del 字典[键] - 删除指定键对应的值
(2)字典.pop(‘键’) - 取出指定键对应的值
字典的相关操作和方法
1.字典的相关操作: in 和 not in
字典不支持+、*、比较大小
2.字典相关函数:len、dict
3.字典相关方法:字典.方法()
字典推导式
结构1: {表达式1:表达式2 for 变量 in序列}
结构2 :{表达式1: 表达式2 for 变量 in 序列 if 条件语句}
-
定义一个变量保存一个学生的信息,学生信息中包括:姓名、年龄、成绩(单科)、电话、性别
stu = {'name': '小明', 'age': 21, 'score': 91, 'tel': 1235415, 'gender': '男'} print(stu)
-
定义一个列表,在列表中保存6个学生的信息(学生信息中包括: 姓名、年龄、成绩(单科)、电话、性别(男、女、不明) )
-
统计不及格学生的个数
-
打印不及格未成年学生的名字和对应的成绩
-
求所有男生的平均年龄
-
打印手机尾号是8的学生的名字
-
打印最高分和对应的学生的名字
-
删除性别不明的所有学生
-
将列表按学生成绩从大到小排序(挣扎一下,不行就放弃)
students = [{'name': '小明', 'age': 21, 'score': 91, 'tel': '1235418', 'gender': '男'}, {'name': '小辉', 'age': 17, 'score': 87, 'tel': '4515121', 'gender': '不明'}, {'name': '小红', 'age': 20, 'score': 79, 'tel': '5512144', 'gender': '女'}, {'name': '小蓝', 'age': 16, 'score': 54, 'tel': '1245178', 'gender': '男'}, {'name': '小紫', 'age': 25, 'score': 92, 'tel': '9881112', 'gender': '女'}, {'name': '小白', 'age': 24, 'score': 59, 'tel': '4131544', 'gender': '男'} ] # 1. 统计不及格学生的个数 count = 0 for stu in students: if stu['score'] < 60: count += 1 print('不及格人数为:', count) # 2. 打印不及格未成年学生的名字和对应的成绩 for stu in students: if stu['score'] < 60 and stu['age'] < 18: print(stu['name'], stu['score']) # 3. 求所有男生的平均年龄 sum_age = 0 count = 0 for stu in students: if stu['gender'] == '男': count += 1 sum_age += stu['age'] print('男生平均年龄为:', sum_age // count) # 4. 打印手机尾号是8的学生的名字 print('手机尾号为8的学生有:') for stu in students: if list(stu['tel'])[-1] == '8': print(stu['name']) # 5. 打印最高分和对应的学生的名字 max_score = students[0]['score'] i = 0 for index, stu in enumerate(students): if stu['score'] > max_score: max_score = stu['score'] i = index print('最高分为:', max_score, '获得最高分的学生为:', students[i]['name']) # 6. 删除性别不明的所有学生 for index, stu in enumerate(students): if stu['gender'] == '不明': del students[index] print(students) # 7. 将列表按学生成绩从大到小排序(挣扎一下,不行就放弃) students = [{'name': '小明', 'age': 21, 'score': 91, 'tel': '1235418', 'gender': '男'}, {'name': '小辉', 'age': 17, 'score': 87, 'tel': '4515121', 'gender': '不明'}, {'name': '小红', 'age': 20, 'score': 79, 'tel': '5512144', 'gender': '女'}, {'name': '小蓝', 'age': 16, 'score': 54, 'tel': '1245178', 'gender': '男'}, {'name': '小紫', 'age': 25, 'score': 92, 'tel': '9881112', 'gender': '女'}, {'name': '小白', 'age': 24, 'score': 59, 'tel': '4131544', 'gender': '男'} ] # 冒泡排序的方法 n = len(students) for j in range(0, n - 1): for i in range(0, n - 1 - j): if students[i]['score'] < students[i + 1]['score']: students[i], students[i + 1] = students[i + 1], students[i] print(students) # 方法二 new_students = [] max_score = 0 i = 0 while students: for index, stu in enumerate(students): if stu['score'] > max_score: max_score = stu['score'] i = index s = students.pop(i) new_students.append(s) max_score = 0 i = 0 print(new_students)
-
-
定义一个变量保存一个班级的信息,班级信息中包括:班级名称、教室位置、班主任信息、讲师信息、班级所有的学生(根据实际情况确定数据类型和具体信息)
class1 = { 'name': 'Python 2202', 'address': '14', 'head_teacher': {'name': '舒玲', 'age': '18', 'gender': '女', 'tel': '1564621'}, 'lecture': {'name': '余婷', 'age': 18, 'gender': '女', 'tel': '7789414'}, 'students': [{'name': '小明', 'age': 21, 'score': 91, 'tel': '1235418', 'gender': '男', 'major': '电子信息'}, {'name': '小辉', 'age': 17, 'score': 87, 'tel': '4515121', 'gender': '男', 'major': '数学'}, {'name': '小红', 'age': 20, 'score': 79, 'tel': '5512144', 'gender': '女', 'major': '会计'}, {'name': '小蓝', 'age': 16, 'score': 54, 'tel': '1245178', 'gender': '男', 'major': '计算机'}, {'name': '小紫', 'age': 25, 'score': 92, 'tel': '9881112', 'gender': '女', 'major': '数学'}, {'name': '小白', 'age': 24, 'score': 59, 'tel': '4131544', 'gender': '男', 'major': '电子信息'} ] }
-
已知一个列表保存了多个狗对应的字典:
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': '母'} ]
-
利用列表推导式获取所有狗的品种
[‘银狐’, ‘法斗’, ‘土狗’, ‘哈士奇’, ‘银狐’, ‘土狗’]
-
利用列表推导式获取所有白色狗的名字
[‘贝贝’, ‘可乐’]
-
给dogs中没有性别的狗添加性别为 ‘公’
-
统计 ‘银狐’ 的数量
# 1. 利用列表推导式获取所有狗的品种 # > ['银狐', '法斗', '土狗', '哈士奇', '银狐', '土狗'] dogs_breed = [dog['breed'] for dog in dogs] print(dogs_breed) # 2. 利用列表推导式获取所有白色狗的名字 # > ['贝贝', '可乐'] dogs_name = [dog['name'] for dog in dogs if dog['color'] == '白色'] print(dogs_name) # 3. 给dogs中没有性别的狗添加性别为 '公' for dog in dogs: dog.setdefault('gender', '公') print(dogs) # 4. 统计 ‘银狐’ 的数量 count = 0 for dog in dogs: if dog['breed'] == '银狐': count += 1 print('银狐的数量为:', count)
-