浅谈Python数据处理csv的应用小结
作者:开心星人 时间:2021-06-10 01:40:41
题目
文件scores.csv包含十位学生的成绩单,表头是"姓名 语文 数学 英语"。请编程完成下述功能。
1)计算每位学生的总分与排名,并将扩充后的学生信息写入文件data.csv中,新文件表头是"姓名 语文 数学 英语 总分 名次";
2)同时,在控制台上分行输出各门课的最高分与最低分以及对应的学生姓名,输出格式为"课程名 :(最高分,学生1,… ,学生n),(最低分,学生1,… ,学生n)";
3)如果总分相同,则同一名次下可能有多人并列,如果最高分或最低分有多人相同,则将这么多人按字母序先后写在同一个元组中。
代码
fr=open("scores.csv","r")
fw=open("data.csv","w")
ls=[]
for line in fr:
line=line.replace("\n","")
ls.append(line.split(","))
ChMax=[0,'']
ChMin=[100,'']
MaMax=[0,'']
MaMin=[100,'']
EnMax=[0,'']
EnMin=[100,'']
#当函数有list或者 dictionary 作为形参时,会改变其实参的值(在函数中若改动其值)
#但是若不想实参的值收到影响,在传参的时候可以使用[].copy方法。list和dictionary都有copy方法。
# def updateMaxMin(Max,Min,score,i):
# if(score>Max[0]):
# Max=[0,'']
# Max[0]=score
# Max[1]=ls[i][0]
# elif(score==Max[0]):
# Max.append(ls[i][0])
# if(score<Min[0]):
# Min=[100,'']
# Min[0]=score
# Min[1]=ls[i][0]
# elif(score==Min[0]):
# Min.append(ls[i][0])
for i in range(1,len(ls)):
sum=eval(ls[i][1])+eval(ls[i][2])+eval(ls[i][3])
#将总分列添加到二维列表中
ls[i].append(sum)
# updateMaxMin(Max=ChMax,Min=ChMin,score=eval(ls[i][1]),i=i)
# updateMaxMin(Max=MaMax,Min=MaMin,score=eval(ls[i][2]),i=i)
# updateMaxMin(Max=EnMax,Min=EnMin,score=eval(ls[i][3]),i=i)
#语文最高分最低分更新
chScore=eval(ls[i][1])
if (chScore > ChMax[0]):
ChMax = [0, '']
ChMax[0] = chScore
ChMax[1] = ls[i][0]
elif (chScore == ChMax[0]):
ChMax.append(ls[i][0])
if (chScore < ChMin[0]):
ChMin = [100, '']
ChMin[0] = chScore
ChMin[1] = ls[i][0]
elif (chScore == ChMin[0]):
ChMin.append(ls[i][0])
#数学最高分最低分更新
maScore=eval(ls[i][2])
if (maScore > MaMax[0]):
MaMax = [0, '']
MaMax[0] = maScore
MaMax[1] = ls[i][0]
elif (maScore == MaMax[0]):
MaMax.append(ls[i][0])
if (maScore < MaMin[0]):
MaMin = [100, '']
MaMin[0] = maScore
MaMin[1] = ls[i][0]
elif (maScore == MaMin[0]):
MaMin.append(ls[i][0])
#英语最高分最低分更新
enScore=eval(ls[i][3])
if (enScore > EnMax[0]):
EnMax = [0, '']
EnMax[0] = enScore
EnMax[1] = ls[i][0]
elif (enScore == EnMax[0]):
EnMax.append(ls[i][0])
if (enScore < EnMin[0]):
EnMin = [100, '']
EnMin[0] = enScore
EnMin[1] = ls[i][0]
elif (enScore == EnMin[0]):
EnMin.append(ls[i][0])
#将二维列表中每一行按照总分从大到小排序
#这里我用的是冒泡排序
for i in range(1,len(ls)):
for j in range(i+1,len(ls)):
if ls[i][4]<ls[j][4]:
ls[i],ls[j]=ls[j],ls[i]
#将名次列添加到二维列表中
ls[1].append(1)
count=2
for i in range(2,len(ls)):
if ls[i][4]==ls[i-1][4]:
ls[i].append(ls[i-1][5])
else:
ls[i].append(count)
count+=1
print("语文:{0},{1}".format(tuple(ChMax),tuple(ChMin)))
print("数学:{},{}".format(tuple(MaMax),tuple(MaMin)))
print("英语:{},{}".format(tuple(EnMax),tuple(EnMin)))
#将表中数据全部转换成字符串
for i in range(len(ls)):
for j in range(len(ls[i])):
ls[i][j]=str(ls[i][j])
#扩充表头
ls[0].append("总分")
ls[0].append("名次")
#写入data.csv
for row in ls:
fw.write(",".join(row)+"\n")
fr.close()
fw.close()
这段代码是可以正常运行的,但是更新最大最小成绩,我想把它分装成一个函数,但是运行失败了,代码我注释掉了,如果大家能看出来哪里错了的话,希望能告诉我一样。这里我只是用了最笨的方法
运行实例
scores.csv
data.csv
控制台
来源:https://blog.csdn.net/qq_55675216/article/details/122360014
标签:Python,数据,处理,csv
0
投稿
猜你喜欢
文案是网站的性格
2009-09-02 13:05:00
python+pyqt实现12306图片验证效果
2023-11-02 07:28:18
Go并发编程sync.Cond的具体使用
2024-05-13 10:41:00
Python调用adb命令实现对多台设备同时进行reboot的方法
2022-08-06 02:40:45
GO语言Defer用法实例分析
2024-04-23 09:49:01
一次mysql迁移的方案与踩坑实战记录
2024-01-13 03:34:42
mysql 8.0.22 安装配置图文教程
2024-01-18 19:47:34
解析Pytorch中的torch.gather()函数
2023-01-29 23:44:40
将Python中的数据存储到系统本地的简单方法
2021-08-22 18:15:55
Python探索之修改Python搜索路径
2021-06-26 20:47:09
Pandas计算元素的数量和频率的方法(出现的次数)
2023-01-02 03:44:58
asp三天学好ADO对象之第二天
2008-10-09 12:49:00
Python高级特性之切片迭代列表生成式及生成器详解
2021-06-25 23:10:13
比较规范的验证Email地址是否正确的正则表达式
2009-07-28 17:55:00
Python学习之用pygal画世界地图实例
2021-03-22 13:04:47
利用ImageAI库只需几行python代码实现目标检测
2023-06-25 15:03:28
MySQL插入emoji表情失败问题的解决方法
2024-01-24 05:26:05
linux系统使用python监控apache服务器进程脚本分享
2021-10-15 00:15:41
分析详解python多线程与多进程区别
2022-01-19 01:13:54
SQL Server重温 事务
2012-08-21 10:48:15