-
定义一个变量保存一个学生的信息,学生信心中包括:姓名、年龄、成绩(单科)、电话、性别
dict1={'name':'张三','age':18,'score':80,'tel':'13547890','gender':'女'}
-
定义一个列表,在列表中保存6个学生的信息(学生信息中包括: 姓名、年龄、成绩(单科)、电话、性别(男、女、不明) )
-
统计不及格学生的个数
list1=[ {'name':'张三','age':18,'score':59,'tel':135678918,'gender':'女'}, {'name':'张四','age':19,'score':80,'tel':13567871,'gender':'男'}, {'name':'张五','age':18,'score':50,'tel':135678618}, {'name':'张六','age':20,'score':79,'tel':13567851,'gender':'男'}, {'name':'张七','age':21,'score':39,'tel':13567841,'gender':'女'}, {'name':'张八','age':20,'score':87,'tel':13567831,'gender':'男'}, ]
count=0 for x in list1: if x['score']<60: count+=1 print(count)
-
打印不及格未成年学生的名字和对应的成绩
for x in list1: if x['age'] < 18 and x['score'] < 60: print(x['name'],x['score']) # 张五 50 张八 55
-
求所有男生的平均年龄
sum=0 count=0 for x in list1: #if x['gender']=='男': (这里用字典[键]会报错,因为字典中有些性别没有) if x.get('gender')=='男': sum+=x['age'] count+=1 print(sum/count) #19.6
-
打印手机尾号是8的学生的名字
for x in list1: if x['tel']%10==8: print(x['name']) # 张三 张五
-
打印最高分和对应的学生的名字
#87 #张八 max_score=list1[0]['score'] names=[list1[0]['name']] for x in list1[1:]: if x['score']>max_score: max_score=x['score'] names.clear() names.append(x['name']) elif x['score']==max_score: names.append(x['name']) print(max_score,names)
-
删除性别不明的所有学生
result=[ x for x in list1 if not(x.get('gender')==None) ] print(result)
-
将列表按学生成绩从大到小排序(挣扎一下,不行就放弃)
#sorted lambda result=sorted(list1,key=lambda x:x['score'],reverse==True) print(result) #冒泡排序 for i in range(1,len(list1)): for j in range(len(list1)-i): if list1[j]['score']<list1[j+1]['score']: list1[j],list1[j+1]=list1[j+1],list1[j] print(list1)
-
-
定义一个变量保存一个班级的信息,班级信息中包括:班级名称、教室位置、班主任信息、讲师信息、班级所有的学生(根据实际情况确定数据类型和具体信息)
class1 = { 'className': 'Python2205', 'classRoom': '11教', 'lecturer': {'name': '婷姐', 'age': 18, 'tel': '13678192302', 'gender': '女'}, 'classTeacher': {'name': '燕子姐', 'age': 18, 'tel': '119', 'QQ': '8282821'}, 'students': [ {'name': 'stu1', 'age': 19, 'tel': '1922333', 'gender': '男', 'linkman': {'name': '张三', 'tel': '11923'}}, {'name': 'stu2', 'age': 28, 'tel': '8727832', 'gender': '男', 'linkman': {'name': '小明', 'tel': '19202'}}, {'name': 'stu3', 'age': 30, 'tel': '291912', 'gender': '女', 'linkman': {'name': '李四', 'tel': '1910283'}}, {'name': 'stu4', 'age': 17, 'tel': '2349183', 'gender': '男', 'linkman': {'name': '老王', 'tel': '109221567'}}, {'name': 'stu5', 'age': 16, 'tel': '27273482', 'gender': '女', 'linkman': {'name': '王五', 'tel': '119283427'}}, {'name': 'stu6', 'age': 22, 'tel': '1242402', 'gender': '男', 'linkman': {'name': '赵六', 'tel': '2091834'}} ]
-
已知一个列表保存了多个狗对应的字典:
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': '母'} ]
-
利用列表推导式获取所有狗的品种
result=[x['breed'] for x in dogs ] print(result)
[‘银狐’, ‘法斗’, ‘土狗’, ‘哈士奇’, ‘银狐’, ‘土狗’]
-
利用列表推导式获取所有白色狗的名字
result=[x['name'] for x in dogs if x['color']=='白色'] print(result)
[‘贝贝’, ‘可乐’]
-
给dogs中没有性别的狗添加性别为 ‘公’
for x in dogs: x.setdefault('gender','公') print(dogs)
-
统计 ‘银狐’ 的数量
count=0 for x in dogs: if x['breed']=='银狐': count+=1 print(count) #2
-
y-day7-字典作业
最新推荐文章于 2024-09-12 12:44:33 发布