S.K. 2023-05-25 02:10 采纳率: 83.3%
浏览 17
已结题

pyrhon程序问题

img

filename = "score.csv"
scores = {"程序设计": [], "体育": [], "经济学": []}

try:
with open(filename, "r") as file:
reader = csv.reader(file)
next(reader) # 跳过文件的第一行(表头)

    for row in reader:
        if len(row) == 4:  # 确保每行都有三个成绩
            _, score1, score2, score3 = row
            scores["程序设计"].append(int(score1))
            scores["体育"].append(int(score2))
            scores["经济学"].append(int(score3))

for subject, subject_scores in scores.items():
    average_score = sum(subject_scores) / len(subject_scores)
    max_score = max(subject_scores)
    min_score = min(subject_scores)

    print(f"科目: {subject}")
    print(f"平均分: {average_score:.2f}")
    print(f"最高分: {max_score}")
    print(f"最低分: {min_score}")
    print()
  • 写回答

3条回答 默认 最新

  • 7*24 工作者 2023-05-25 09:49
    关注

    直接用pandas去取csv文件的方式是最简单的,通过列索引就可以把数据给过滤出来,然后转化成列表,然后再求平均分、最高分、最低分。

    
    import pandas as pd
    # scores = {'程序设计': [], '体育': [], '经济学': []}
    scores = {}
    
    df = pd.read_csv('score.csv', encoding='utf-8')  # 如果字符编码gbk的,需要把 utf-8 改成 gbk
    scores['程序设计'] = df['程序设计'].to_list()
    scores['体育'] = df['体育'].to_list()
    scores['经济学'] = df['经济学'].to_list()
    
    for k,v in scores.items():
        print( '{}的平均分:{},最高分:{},最低分:{}'.format( k,   round(sum(v) / len(v), 2), max(v), min(v)  ) )
    
    

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 6月11日
  • 已采纳回答 6月3日
  • 创建了问题 5月25日

悬赏问题

  • ¥20 python爬虫遇到空文本取不出来
  • ¥15 x264库中预测模式字IPM、运动向量差MVD、量化后的DCT系数的位置
  • ¥15 curl 命令调用正常,程序调用报 java.net.ConnectException: connection refused
  • ¥20 关于web前端如何播放二次加密m3u8视频的问题
  • ¥15 使用百度地图api 位置函数报错?
  • ¥15 metamask如何添加TRON自定义网络
  • ¥66 关于川崎机器人调速问题
  • ¥15 winFrom界面无法打开
  • ¥30 crossover21 ARM64版本安装软件问题
  • ¥15 mymetaobjecthandler没有进入