问题描述

利用记事本创建一个a.csv文件,内容如下:

姓名,语文,数学,英语,总分
张三,80,80,80,240
李四,90,90,90,270
王五,70,70,70,210
赵六,70,80,90,240

编程完成以下功能:

  • 1.读取a.csv文件的数据内容
  • 2.最后增加一列,名称为‘排名’
  • 3.根据总分得到正确的排名并打印输出
  • 4.将包含排名列的所有数据保存为a.json文件
  • 5.提交代码和运行截图。

代码实现

""" @author: shoo Wang @contact: wangsuoo@foxmail.com @file: demo04.py @time: 2020/4/27 0027 """

import json

# f1 负责读入文件, f2 负责写入文件 + 代表同时具备读写功能
f1 = open('./a.csv', 'r+', encoding='utf-8')
f2 = open('./a.json', 'w+', encoding='utf-8')

# 使用列表推导式, 获取二维结构
table = [i.strip('\n').split(',') for i in f1.readlines()]

# 表头增加排名,然后我们就不需要表头了,因为它没法排序
table[0].append('排名')

# 由于 sort 函数和 extend 函数都是没有返回值的
# 所以我们必须事先存储待处理变量,如果题目中没给总分可以 sum([int(j) for j in x[1:]])
sortList = table[1:]
sortList.sort(key=lambda x: x[-1], reverse=True)

# 增加排名数字
for i in range(len(sortList)):
    sortList[i].append(str(i + 1))

# 表头加上已经排好序的表体
listHead = table[:1]
listHead.extend(sortList)

# 得到 Python 数据类型的 listHead
# 现在转化成 json 数据类型
# 1.首先建立映射关系,zip() 函数返回的是 zip 类型
# 我们要把 zip 类型转化成 字典类型;
toJson = []
for i in listHead[1:]:
    toJson.append(dict(zip(listHead[0], i)))

# 2.写入文件, dump 直接写入文件, dumps 返回 json 数据
json.dump(toJson, f2, ensure_ascii=False, indent=4)

# 释放资源
f1.close()
f2.close()

我也不是一次编写完成的,是在不断的试错中一步一步的解决这个问题的,令我印象最深刻的就是这个sort函数的用法,需要传入一个回调函数,这里是以列表元素的最后一个值作为key,我之前在做的时候忘记了题目中已经给了总分,还使用了sum([int(j) for j in x[1:]])这个排序,多此一举。

代码截图