文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Python如何数据处理csv的应用

2023-06-26 04:37

关注

今天小编给大家分享一下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=2for 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+=1print("语文:{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.csvfor row in ls:      fw.write(",".join(row)+"\n")fr.close()fw.close()

这段代码是可以正常运行的,但是更新最大最小成绩,我想把它分装成一个函数,但是运行失败了,代码我注释掉了,如果大家能看出来哪里错了的话,希望能告诉我一样。这里我只是用了最笨的方法

运行实例

scores.csv

Python如何数据处理csv的应用

data.csv

Python如何数据处理csv的应用

控制台

Python如何数据处理csv的应用

以上就是“Python如何数据处理csv的应用”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯