浅谈Python数据处理csv的应用小结

 更新时间:2022年01月10日 16:50:17   作者:开心星人  
这篇文章主要介绍了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的简单应用的文章就介绍到这了,更多相关Python数据处理csv内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python简单调用MySQL存储过程并获得返回值的方法

    Python简单调用MySQL存储过程并获得返回值的方法

    这篇文章主要介绍了Python调用MySQL存储过程并获得返回值的方法,涉及Python操作MySQL存储过程的使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-07-07
  • Python MySQLdb Linux下安装笔记

    Python MySQLdb Linux下安装笔记

    这篇文章主要介绍了Python MySQLdb Linux下安装笔记,本文分别讲解了快速安装和手动编译安装两种方法,并分别讲解了操作步骤,需要的朋友可以参考下
    2015-05-05
  • 浅谈Python中的函数(def)及参数传递操作

    浅谈Python中的函数(def)及参数传递操作

    这篇文章主要介绍了浅谈Python中的函数(def)及参数传递操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-05-05
  • python的迭代器,生成器和装饰器你了解吗

    python的迭代器,生成器和装饰器你了解吗

    这篇文章主要为大家详细介绍了python的迭代器,生成器和装饰器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02
  • python 多线程串行和并行的实例

    python 多线程串行和并行的实例

    今天小编就为大家分享一篇python 多线程串行和并行的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-02-02
  • python利用print()打印田字格练习题详解

    python利用print()打印田字格练习题详解

    print在 Python3.x是一个函数,但在Python2.x版本不是一个函数,只是一个关键字,这篇文章主要给大家介绍了关于python利用print()打印田字格练习题的相关资料,需要的朋友可以参考下
    2024-05-05
  • python利用小波分析进行特征提取的实例

    python利用小波分析进行特征提取的实例

    今天小编就为大家分享一篇python利用小波分析进行特征提取的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-01-01
  • Python模块结构与布局操作方法实例分析

    Python模块结构与布局操作方法实例分析

    这篇文章主要介绍了Python模块结构与布局操作方法,结合实例形式分析了Python模块与布局的相关概念、使用方法与相关注意事项,需要的朋友可以参考下
    2017-07-07
  • Python在cmd上打印彩色文字实现过程详解

    Python在cmd上打印彩色文字实现过程详解

    这篇文章主要介绍了Python在cmd上打印彩色文字实现过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-08-08
  • tensorboard显示空白的解决

    tensorboard显示空白的解决

    今天小编就为大家分享一篇tensorboard显示空白的解决,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-02-02

最新评论