自动创建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}')
如有帮助,望采纳!谢谢!