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

如何用文件统计成绩,
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- CSDN专家-天际的海浪 2021-11-12 03:34关注
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}')
如有帮助,望采纳!谢谢!
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用