求助,如何从 CSV 文件里提取数据
0

python小白,想问一下各位大佬,怎么从csv格式文件里提取一列数据并计算出平均值?
csv:
姓 名 学号 科目1 科目2 科目3
李 一 10 89 67 54
王 二 11 87 75 86
赵 三 12 54 78 86
假设我要打印科目1,2,3的平均成绩,结果如下
科目1 | 科目2 | 科目3
76.67 | 74.33 | 68.33
然后还要打印出每一科分数最高的人,结果如下
科目 | 姓 | 名
科目1 | 李 | 一
科目2 | 赵 | 三
科目3 | 王 | 二
科目3 | 赵 | 三(和王二并列需要同时打印出两者的名字)
要怎么实现呢? 我的代码:

import csv
with open('data.csv', newline = '') as f:
reader = csv.reader(f)

next(reader)

r1 = [float(row[2]) for row in reader]
avg1 = round(sum(r1) / len(r1),2)

r2 = [float(row[3]) for row in reader]
avg2 = round(sum(r2) / len(r2),2)

r3 = [float(row[4]) for row in reader]
avg3 = round(sum(r3) / len(r3),2)

print("================================================")
print("{0:^10}|{1:^10}|{2:^10}|{3:^10}".format(avg1,avg2,avg3))

报错说除数不能为0,可是我单独打印r1是没错的,r2,r3打印出来是空的list,搞不清楚为什么,求大神帮忙!

讨论数量: 0
(= ̄ω ̄=)··· 暂无内容!

  • 请注意单词拼写,以及中英文排版,参考此页
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`, 更多语法请见这里 Markdown 语法
  • 支持表情,使用方法请见 Emoji 自动补全来咯,可用的 Emoji 请见 :metal: :point_right: Emoji 列表 :star: :sparkles:
  • 上传图片, 支持拖拽和剪切板黏贴上传, 格式限制 - jpg, png, gif
  • 发布框支持本地存储功能,会在内容变更时保存,「提交」按钮点击时清空
  请勿发布不友善或者负能量的内容。与人为善,比聪明更重要!