Juvenile16 2022-12-18 23:04 采纳率: 100%
浏览 58
已结题

Python处理CSV文件

假设grade.csv文件中存放着选手们的打分成绩,包含序号、专家打分、观众打分。请根据专家打分占40%,观众打分占60%的比例计算选手的总评成绩,并按序号、总评成绩(取两位小数)两列写入另一个文件overall.txt中并在显示写入的文件结果。要求分别用read、readline、readlines、遍历文件、快速列表访问方式读取grade.csv文件实现,程序分别命名为:选手评分-read.py、选手评分-readline.py、选手评分-readlines.py、选手评分-遍历文件.py、选手评分-快速列表访问方式.py、。
输出效果如下所示:

img

原数据:
序号 专家打分 观众打分
1 82 " 96 "
2 81 " 88 "
3 78 " 63 "
4 95 " 64 "
5 89 " 88 "
6 77 " 87 "

  • 写回答

3条回答 默认 最新

  • CSDN专家-showbo 2022-12-19 10:06
    关注

    csv格式不对吧,怎么有双引号
    遍历文件、快速列表访问方式读取grade.csv这2个没明白什么意思。

    下面是read,readline和readlines的实现,注意csv格式内容和代码中一样

    '''序号 专家打分 观众打分
    1 82 96
    2 81 88
    3 78 63
    4 95 64
    5 89 88
    6 77 87
    '''
    lst=[]
    with open('grade.csv') as f:
        #lst=f.read().split('\n')
        #lst=f.readlines()
        while True:
            l=f.readline().strip()
            if not l:
                break
            lst.append(l)
    
    lst=[x.strip().split() for x in lst]
    with open('overall.txt','w',encoding='utf-8') as f:
        f.writelines('序号\t总评分')
        for item in lst:
            total=float(item[1])*0.4+float(item[2])*0.6
            f.write(f'\n{item[0]}\t{total:.2f}')
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 12月27日
  • 已采纳回答 12月19日
  • 创建了问题 12月18日

悬赏问题

  • ¥15 用土力学知识进行土坡稳定性分析与挡土墙设计
  • ¥70 PlayWright在Java上连接CDP关联本地Chrome启动失败,貌似是Windows端口转发问题
  • ¥15 帮我写一个c++工程
  • ¥30 Eclipse官网打不开,官网首页进不去,显示无法访问此页面,求解决方法
  • ¥15 关于smbclient 库的使用
  • ¥15 微信小程序协议怎么写
  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?