-
定义一个变量保存一个学生的信息,学生信心中包括:姓名、年龄、成绩(单科)、电话、性别
xuesheng = { {'name': 'stu1', 'age': 20, 'gender': '男', 'tel': '11987223', 'score': 85}, {'name': 'stu2', 'age': 22, 'gender': '女', 'tel': '8293212', 'score': 99}, {'name': 'stu3', 'age': 25, 'gender': '女', 'tel': '727332', 'score': 100}, {'name': 'stu4', 'age': 17, 'gender': '男', 'tel': '563743', 'score': 56}, {'name': 'stu5', 'age': 23, 'gender': '男', 'tel': '0928322', 'score': 66} } -
定义一个列表,在列表中保存6个学生的信息(学生信息中包括: 姓名、年龄、成绩(单科)、电话、性别(男、女、不明) )
xuesheng1 = [ {'name': 'stu1', 'age': 20, 'gender': '男', 'tel': '11987228', 'score': 85}, {'name': 'stu2', 'age': 22, 'gender': '女', 'tel': '8293212', 'score': 99}, {'name': 'stu3', 'age': 25, 'gender': '女', 'tel': '727338', 'score': 100}, {'name': 'stu4', 'age': 17, 'gender': '男', 'tel': '563743', 'score': 56}, {'name': 'stu5', 'age': 23, 'gender': '不明', 'tel': '0928322', 'score': 66} ]- 统计不及格学生的个数
geshu = [x['score'] for x in xuesheng1 if x['score'] < 60] print(geshu) i = 0 for x in geshu: i += 1 print(i)- 打印不及格未成年学生的名字和对应的成绩
a = [x['name'] for x in xuesheng1 if x['score'] < 60 and x['age'] < 18] print(a) b = [x['age'] for x in xuesheng1 if x['score'] < 60 and x['age'] < 18] print(b) print(a, b)- 求所有男生的平均年龄
b = [x['age'] for x in xuesheng1 if x['gender'] == '男'] print(int(sum(b)/(len(b))))- 打印手机尾号是8的学生的名字
c = [x['name'] for x in xuesheng1 if int(x['tel']) % 10 == 8] print(c)- 打印最高分和对应的学生的名字
d = [x['score'] for x in xuesheng1 ] f = [x['name'] for x in xuesheng1 if x['score'] == max(d)] print(f'名字{f}, 成绩{max(d)}')- 删除性别不明的所有学生
for x in xuesheng1: if x['gender'] == '不明': xuesheng1.remove(x) print(xuesheng1)- 将列表按学生成绩从大到小排序(挣扎一下,不行就放弃)
-
定义一个变量保存一个班级的信息,班级信息中包括:班级名称、教室位置、班主任信息、讲师信息、班级所有的学生(根据实际情况确定数据类型和具体信息)
class1 = {
'name': 'Python2206',
'address': '14教',
'lecturer': {
'name': '余婷',
'age': 18,
'qq': '726550822'
},
'class_teacher': {
'name': '吴静',
'age': 18,
'tel': '110'
},
'all_student': [
{'name': 'stu1', 'age': 20, 'gender': '男', 'tel': '11987223', 'linkman': {'name': '张三', 'tel': '81923'}},
{'name': 'stu2', 'age': 22, 'gender': '女', 'tel': '8293212', 'linkman': {'name': '小明', 'tel': '6666'}},
{'name': 'stu3', 'age': 25, 'gender': '女', 'tel': '727332', 'linkman': {'name': '李四', 'tel': '829333'}},
{'name': 'stu4', 'age': 19, 'gender': '男', 'tel': '563743', 'linkman': {'name': '老王', 'tel': '778822'}},
{'name': 'stu5', 'age': 23, 'gender': '男', 'tel': '0928322', 'linkman': {'name': '赵六', 'tel': '829101'}}
]
}
-
已知一个列表保存了多个狗对应的字典:
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': '母'} ]-
利用列表推导式获取所有狗的品种
[‘银狐’, ‘法斗’, ‘土狗’, ‘哈士奇’, ‘银狐’, ‘土狗’]
pz = [x['breed'] for x in dogs] print(pz) -
利用列表推导式获取所有白色狗的名字
[‘贝贝’, ‘可乐’]
names = [x['name'] for x in dogs if x['color'] == '白色'] print(names) -
给dogs中没有性别的狗添加性别为 ‘公’
names = [x.setdefault('gender', '公') for x in dogs] print(dogs)-
统计 ‘银狐’ 的数量
count = 0 for x in dogs: if x['breed'] == '银狐': count += 1 print(count)
-
本文通过Python编程实现了一系列数据处理任务,包括学生信息管理、列表操作、字典使用等。涉及统计、筛选、排序及数据结构的操作,展示了Python在处理数据方面的强大能力。同时,还介绍了班级信息管理和狗狗数据的处理,涵盖了数据提取、过滤和更新等操作。
2451

被折叠的 条评论
为什么被折叠?



