您好,登录后才能下订单哦!
今天小编给大家分享一下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
控制台
以上就是“Python如何数据处理csv的应用”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。