总结
字典
与列表区别,多个数据,数据类型相同用列表,数据类型不一样用字典
1)是容器型数据类型;将{}作为容器的标志,里面多个键值对用逗号隔开
2)字典是可变的(支持增删改);字典是无序的(不支持下标),元素顺序不影响结果,
3)对元素的要求,字典的元素是键值对
a.键的要求:键必须是不可变的类型的数据(数字,字符串,布尔,元组等),键是唯一的
b.值的要求:没有要求
查单个 一次获取一个值
语法1: 字典[键] 获取中括号中键对应的值
语法2: 字典.get(键) 获取中括号中键对应的值
字典.get(键,默认值) 键不存在的情况下,返回默认值
区别:[]获取不存在的会报错,get()获取不存在的不会报错(None)
1.增,改 - 添加键值对
1)字典[键] = 值 如果键存在就修改指定键对应的值,如果不存在就添加值对
2)字典.setdefault(键,值) 如果没有就添加,有就不动字典
2.删
1)del 字典[键] 删除指定键对应的值对
2)字典.pop(键) 取出指定键的值
作业
-
定义一个变量保存一个学生的信息,学生信心中包括:姓名、年龄、成绩(单科)、电话、性别
class1 = {'name':'余建','age':'28','english_score':'135','tel':'1355','gender ':'男'}
-
定义一个列表,在列表中保存6个学生的信息(学生信息中包括: 姓名、年龄、成绩(单科)、电话、性别(男、女、不明) )
students = [ {'name': '小明', 'age': 18, 'score': 100, 'tel': '110', 'gender': '男'}, {'name': '小花', 'age': 20, 'score': 98, 'tel': '120', 'gender': '女'}, {'name': '张三', 'age': 30, 'score': 90, 'tel': '119', 'gender': '男'}, {'name': '王二', 'age': 28, 'score': 95, 'tel': '2383', 'gender': '男'}, {'name': '赵敏', 'age': 17, 'score': 59, 'tel': '23428', 'gender': '女'}, {'name': '李四', 'age': 22, 'score': 89, 'tel': '1234','gender': '不明'} ]
-
统计不及格学生的个数
count = 0 for x in students: if x['score'] < 60: count += 1 print(count)
-
打印不及格未成年学生的名字和对应的成绩
for x in students: if x['score'] < 60 and x['age'] <18: print(x['name'],x['score'])
-
求所有男生的平均年龄
scores = [] for x in students: if x['gender'] == '男': scores.append(x['age']) print(sum(scores)/len(scores))
-
打印手机尾号是8的学生的名字
for x in students: if int(x['tel']) % 10 == 8: print(x['name'])
-
打印最高分和对应的学生的名字
max_score = students[0]['score'] names = [students[0]['name']] for x in students[1:]: score = x['score'] if score > max_score: max_score = score names.clear() names.append(x['name'])
-
删除性别不明的所有学生
for x in students: if x['gender'] == '不明': students.remove(x) print(students)
-
将列表按学生成绩从大到小排序(挣扎一下,不行就放弃)
min_score = students[0]['score'] names = [students[0]['name']] new_students = [] for x in students[0:]: score = x['score'] if score <= min_score: new_students.append(x) print(new_students)
-
-
定义一个变量保存一个班级的信息,班级信息中包括:班级名称、教室位置、班主任信息、讲师信息、班级所有的学生(根据实际情况确定数据类型和具体信息)
class1 = { 'grade':'python2201', 'location':'12', 'teacher':{ 'name':'yt', 'gender':'女', 'tel':'1355555' }, 'class_teacher': { 'name': '张瑞燕', 'gender': '女', 'tel': '110', 'age': 20, 'QQ': '617818271' }, 'students':{ {'name': '余', 'gender': '男', 'age': 18, 'score': 100, 'education': '专科'}, {'name': '花', 'gender': '女', 'age': 20, 'score': 98, 'education': '本科'}, {'name': '张', 'gender': '男', 'age': 30, 'score': 90, 'education': '本科'}, {'name': '李', 'gender': '男', 'age': 22, 'score': 70, 'education': '专科'}, {'name': '冉', 'gender': '男', 'age': 28, 'score': 95, 'education': '本科'}, {'name': '赵', 'gender': '女', 'age': 27, 'score': 99, 'education': '专科'}, {'name': '王', 'gender': '男', 'age': 22, 'score': 89, 'education': '本科'} } }
-
已知一个列表保存了多个狗对应的字典:
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': '母'} ]
-
利用列表推导式获取所有狗的品种
[‘银狐’, ‘法斗’, ‘土狗’, ‘哈士奇’, ‘银狐’, ‘土狗’]
print([x['breed'] for x in dogs])
-
利用列表推导式获取所有白色狗的名字
[‘贝贝’, ‘可乐’]
print([x['name'] for x in dogs if x['color'] == '白色'])
-
给dogs中没有性别的狗添加性别为 ‘公’
for x in dogs: x.update({'gender':'公'}) print(dogs)
-
统计 ‘银狐’ 的数量
count = 0 for x in dogs: if x['breed'] == '银狐': count += 1 print(count)
-