-
定义一个变量保存一个学生的信息,学生信心中包括:姓名、年龄、成绩(单科)、电话、性别
stu={'name':'小明','age':18,'score':89,'number':'1496565','sex':'男'}
-
定义一个列表,在列表中保存6个学生的信息(学生信息中包括: 姓名、年龄、成绩(单科)、电话、性别(男、女、不明) )
stu=[ {'name':'小明','age':16,'score':45,'number':'149','sex':'男'}, {'name':'小红','age':19,'score':86,'number':'145','sex':'女'}, {'name':'小花','age':17,'score':59,'number':'128','sex':'女'}, {'name':'大明','age':20,'score':88,'number':'155','sex':'男'}, {'name':'小白','age':19,'score':90,'number':'121','sex':'男'}, {'name':'小兰','age':20,'score':99,'number':'134','sex':'女'} ]
-
统计不及格学生的个数
count=0 for i in stu: if i['score']<60: count+=1 print(count)
-
打印不及格未成年学生的名字和对应的成绩
for i in stu: if i['score']<60 and i['age']<18: print(i['name'],i['score'])
-
求所有男生的平均年龄
sum=0 count=0 for i in stu: if i['sex']=='男': sum+=i['age'] count+=1 print(sum//count)
-
打印手机尾号是8的学生的名字
for i in stu: if i['number'][-1]=='8': print(i['name'])
-
打印最高分和对应的学生的名字
list1=[i['score'] for i in stu] max1=max(list1) for i in stu: if i['score']==max1: print(i['name'],i['score']) ----------------------------------------- max2=stu[0]['score'] names=[stu[0]['name']] for x in stu: s=x['score'] if s>max: names.clear() names.append(x['name']) elif: names.append(x['name']) print(max,names)
-
删除性别不明的所有学生
for i in range(len(stu)): if stu[i]['sex']=='不明': del stu[i] print(stu)
-
将列表按学生成绩从大到小排序(挣扎一下,不行就放弃)
list1=[x['score'] for x in stu] list1.sort(reverse=True) stu1=[] for j in range(len(list1)): for i in range(len(stu)): if stu[i]['score']==list1[j]: stu1.append(stu[i]) print(stu1) ----------------------------------------------- students.sort(key=lambda x: x['score'], reverse=True) print(students) -----------------------------------------------
-
-
定义一个变量保存一个班级的信息,班级信息中包括:班级名称、教室位置、班主任信息、讲师信息、班级所有的学生(根据实际情况确定数据类型和具体信息)
class1 = { 'name': 'Python2107', 'address': '18教', 'lecturer': [ {'name': '余婷', 'qq': '726550822', 'age': 18}, {'name': '张瑞燕', 'qq': '67273', 'age': 28} ], 'students': [ {'name': 'stu1', 'tel': '102', 'gender': '男', 'age': 20, 'linkman': {'name': '张三', 'tel': '150'}}, {'name': 'stu2', 'tel': '139', 'gender': '女', 'age': 19, 'linkman': {'name': '李四', 'tel': '109'}}, {'name': 'stu3', 'tel': '168', 'gender': '女', 'age': 30, 'linkman': {'name': 'Bob', 'tel': '100'}}, {'name': 'stu6', 'tel': '192', 'gender': '女', 'age': 20, 'linkman': {'name': '小明', 'tel': '130'}}, {'name': 'stu7', 'tel': '099', 'gender': '男', 'age': 25, 'linkman': {'name': '小花', 'tel': '023'}} ] }
-
已知一个列表保存了多个狗对应的字典:
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': '母'} ]
-
利用列表推导式获取所有狗的品种
[‘银狐’, ‘法斗’, ‘土狗’, ‘哈士奇’, ‘银狐’, ‘土狗’]
list1=[i['breed'] for i in dogs]
-
利用列表推导式获取所有白色狗的名字
[‘贝贝’, ‘可乐’]
list1=[i['name'] for i in dogs if i['color']=='白色']
-
给dogs中没有性别的狗添加性别为 ‘公’
for i in dogs: i.setdefault('gender','公')
-
统计 ‘银狐’ 的数量
count=0 for i in dogs: if i['breed']=='银狐': count+=1 print(count)
-
day8-字典作业
最新推荐文章于 2023-09-09 10:54:35 发布