with open('成绩.txt', 'r') as f: student_list = [] f.readline() for line in f.readlines(): line = line.replace("\n", '') a = line.split(',') student_dict = { '学号': a[0], '姓名': a[1], '语文': float(a[2]), '数学': float(a[3]), '英语': float(a[4]) } student_dict['总分'] = student_dict['语文'] + student_dict['数学'] + student_dict['英语'] student_list.append(student_dict) student_list = sorted(student_list, key=lambda x: x['总分'], reverse=True) print('学号 姓名 总分') for i, student in enumerate(student_list): print("{} {} {}".format(student['学号'], student['姓名'], student['总分']))
时间: 2024-01-25 16:03:10 浏览: 60
mysql-5.7.38源码包及所需boost_1_59_0合集
这段代码是读取一个文本文件"成绩.txt",文件中每一行代表一个学生的成绩信息,包括学号、姓名、语文成绩、数学成绩和英语成绩。代码将每个学生的信息存储在一个字典中,并将所有学生的字典存储在一个列表中。列表中的每个学生字典包括学号、姓名、语文成绩、数学成绩、英语成绩和总分。总分是语文、数学和英语成绩的总和。
代码将列表按照学生总分从高到低排序,并打印排名信息,包括学号、姓名和总分。最后输出的结果类似于:
学号 姓名 总分
1001 张三 290.0
1002 李四 285.5
1003 王五 280.0
...
阅读全文