「已注销」 2021-11-11 22:30 采纳率: 100%
浏览 65
已结题

如何用文件统计成绩,

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

  • 写回答

1条回答 默认 最新

  • 关注
    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

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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 11月23日
  • 已采纳回答 11月15日
  • 创建了问题 11月11日