Python利用文件输入学生数据,给成绩排名,输出到新文件

【问题描述】

文件score.txt中存储了若干学生的姓名、学号和3门考试课的成绩

要求:按总分从高到低输出学生成绩记录(按学号、姓名、三门课成绩的顺序)到文件sorted.txt

【输入形式】

文件中每行为一个学生信息,形式为:姓名,学号,成绩1,成绩2,成绩3

【输出形式】

按照总分从高到低输出学生信息到文件sorted.txt,每行一个学生的信息,输出形式为:学号,姓名,成绩1,成绩2,成绩3

【样例输入】

Zhang,2011010101,66,77,88

Li,2011010102,55,48,68

Wang,2011010103,78,87,92

Zhao,2011010104,53,34,55

Liu,2011010105,55,65,75

【样例输出】

2011010103,Wang,78,87,92

2011010101,Zhang,66,77,88

2011010105,Liu,55,65,75

2011010102,Li,55,48,68

2011010104,Zhao,53,34,55

import csv

with open("score.txt","r",newline="", encoding='utf-8') as fileObj:
    li = list(csv.reader(fileObj))
print(*li,sep='\n')
li.sort(key=lambda x: sum(map(float,x[2:])), reverse=True)
print('----------------------')
for v in li:
    v[0],v[1] = v[1],v[0]
print(*li,sep='\n')
with open("sorted.txt","w",newline="", encoding='utf-8') as fileObj:
    csv.writer(fileObj).writerows(li)