浅谈Python数据处理csv的应用小结
作者:开心星人 发布时间:2021-06-10 01:40:41
标签:Python,数据,处理,csv
题目
文件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
0
投稿
猜你喜欢
- 概述从今天开始, 小白我将带领大家一起来补充一下 数据库的知识.MySQL 安装下载地址:https://dev.mysql.com/dow
- JDBC连接MySQL数据库关键的四个步骤1、查找驱动程序MySQL目前提供的Java驱动程序为Connection/J,可以从MySQL官
- 网页过渡是指当浏览者进入或离开网页时,页面呈现的不同的刷新效果,比如卷动、百叶窗等。注:通过模板所建网页无法添加网页过渡效果!制作步骤:1、
- 带参数的二维码对于渠道营销推广来说是很有用的,可以获得多个带不同场景值的二维码,用户扫描后,公众号可以接收到事件推送,可喜的是微信开通了这个
- 相比SQL Server 2000提供的FOR XML查询,SQL Server 2005版本对现有功能增强的基础上增加了不少新功能,最为吸
- 1 文件处理形式 近期由于处理大量数据,所以对于采用python进行处理文件的一些操作也打算整理一下;接下
- 打开网页,然后将javascript:document.body.contentEditable='true';
- (一)行号显示和排序 1.SQL Server的行号 A.SQL 2000使用identity(int,1,1)和临时表,可以显示行号 SE
- python除了关键字(keywords)和内置的类型和函数(builtins),更多的功能是通过libraries(即modules)来提
- 在ASP输出页面只是调出数据库里内容展现给用户看没有使用SESSION等动态属性,是可以CACHE的,以加快访问速度具体操作方法如下:在as
- 第一次使用python写程序,确实比C/C++之类方便许多。既然这个抽奖的数据不大,对效率要求并不高,所以采用python写,更加简洁、清晰
- 本人曾经用过的备份方式有:mysqldump、mysqlhotcopy、BACKUP TABLE 、SELECT INTO OUTFILE,
- 引言除非您正在对服务进行原型设计,否则您可能会关心应用程序的内存使用情况。内存占用更小,基础设施成本降低,扩展变得更容易/延迟。尽管 Go
- 生生把写过的java版改成javascript版,第一次写,很不专业,见谅。唉,我是有多闲。var Sudoku = { &nbs
- 一.背景一道ctf题,通过破解2048游戏获得flag游戏的规则很简单,需要控制所有方块向同一个方向运动,两个相同数字方块撞在一起之后合并成
- 简介:psutil(进程和系统实用程序)是一个跨平台库,用于检索Python中运行进程和系统利用率(CPU、内存、磁盘、网络、传感器)的信息
- 环境: 开发的IDE:JBuilderX 使用的数据库:MS Sql Server 2000 使用的数据库驱动:JSQL Driver(JD
- 使用 IE8 时发现其原生的 JSON 解析器存在 Bug,让我们先用 IE8 打开 DEMO 页面体验下。http://lab.grace
- 正文之前上午给爸爸打了个电话庆祝他50岁生日,在此之前搞了个大扫除,看了会知乎,到实验室已经十一点多了。约喜欢的妹子吃饭失败,以至于工作积极
- 本文实例讲述了php实现的美国50个州选择列表。分享给大家供大家参考。具体如下:这里展示的是php生成的美国50个州的选择列表,自动选择当前