如何用文件统计成绩,

自动创建1个score.txt文件,存放200个学生的计算机课成绩,包含学号、平时成绩、期末成绩三列。请根据平时成绩占40%,期末成绩占60%的比例计算总评成绩。并按总评成绩从高到低的顺序将学号、总评成绩两列写入另一个文件scored.txt中,同时在屏幕上输出按总评成绩90分以上、8089,7079,60~69,60以下各成绩区间的人数和班级总平均分(取小数点后两位)

import csv
import random
# 自动创建1个score.txt文件
with open("score.txt","w",newline="", encoding='utf-8') as fileObj:
    liw = [["学号","平时成绩","期末成绩"]]
    for i in range(200):
        liw.append([i+1000,random.randint(50,100),random.randint(50,100)])
    csv.writer(fileObj).writerows(liw)

# 读取score.txt文件
with open("score.txt","r",newline="", encoding='utf-8') as fileObj:
    li = list(csv.reader(fileObj))
# 创建1个scored.txt文件
with open("scored.txt","w",newline="", encoding='utf-8') as fileObj:
    liw2 = []
    for n,p,m in li[1:]:
        liw2.append([n,float(p)*0.4+float(m)*0.6])
    liw2.sort(key=lambda x: x[1],reverse=True)
    csv.writer(fileObj).writerow(["学号","总评成绩"])
    csv.writer(fileObj).writerows(liw2)

sa=sb=sc=sd=se=0
scsum = 0
for n,s in liw2:
    if s>=90:
        sa += 1
    elif s>=80:
        sb += 1
    elif s>=70:
        sc += 1
    elif s>=60:
        sd += 1
    else:
        se += 1
    scsum += s
print(f'总评成绩90分以上的人数:{sa}')
print(f'总评成绩80~89区间的人数:{sb}')
print(f'总评成绩70~79区间的人数:{sc}')
print(f'总评成绩60~69区间的人数:{sd}')
print(f'总评成绩60以下的人数:{sa}')
print(f'班级总平均分:{scsum/len(liw2):.2f}')

img

img

img

如有帮助,望采纳!谢谢!