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

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日

悬赏问题

  • ¥20 如何推断此服务器配置
  • ¥15 关于github的项目怎么在pycharm上面运行
  • ¥15 内存地址视频流转RTMP
  • ¥100 有偿,谁有移远的EC200S固件和最新的Qflsh工具。
  • ¥15 找一个QT页面+目标识别(行人检测)的开源项目
  • ¥15 有没有整苹果智能分拣线上图像数据
  • ¥20 有没有人会这个东西的
  • ¥15 cfx考虑调整“enforce system memory limit”参数的设置
  • ¥30 航迹分离,航迹增强,误差分析
  • ¥15 Chrome Manifest扩展引用Ajax-hook库拦截请求失败