欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談Python數(shù)據(jù)處理csv的應(yīng)用小結(jié)

 更新時(shí)間:2022年01月10日 16:50:17   作者:開心星人  
這篇文章主要介紹了Python數(shù)據(jù)處理csv的簡單應(yīng)用,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

題目

文件scores.csv包含十位學(xué)生的成績單,表頭是"姓名 語文 數(shù)學(xué) 英語"。請編程完成下述功能。
1)計(jì)算每位學(xué)生的總分與排名,并將擴(kuò)充后的學(xué)生信息寫入文件data.csv中,新文件表頭是"姓名 語文 數(shù)學(xué) 英語 總分 名次";
2)同時(shí),在控制臺上分行輸出各門課的最高分與最低分以及對應(yīng)的學(xué)生姓名,輸出格式為"課程名 :(最高分,學(xué)生1,… ,學(xué)生n),(最低分,學(xué)生1,… ,學(xué)生n)";
3)如果總分相同,則同一名次下可能有多人并列,如果最高分或最低分有多人相同,則將這么多人按字母序先后寫在同一個(gè)元組中。

代碼

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,'']

#當(dāng)函數(shù)有l(wèi)ist或者 dictionary 作為形參時(shí),會改變其實(shí)參的值(在函數(shù)中若改動其值)
#但是若不想實(shí)參的值收到影響,在傳參的時(shí)候可以使用[].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])

    #數(shù)學(xué)最高分最低分更新
    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("數(shù)學(xué):{},{}".format(tuple(MaMax),tuple(MaMin)))
print("英語:{},{}".format(tuple(EnMax),tuple(EnMin)))

#將表中數(shù)據(jù)全部轉(zhuǎn)換成字符串
for i in range(len(ls)):
      for j in range(len(ls[i])):
          ls[i][j]=str(ls[i][j])

#擴(kuò)充表頭
ls[0].append("總分")
ls[0].append("名次")

#寫入data.csv
for row in ls:
      fw.write(",".join(row)+"\n")
fr.close()
fw.close()

這段代碼是可以正常運(yùn)行的,但是更新最大最小成績,我想把它分裝成一個(gè)函數(shù),但是運(yùn)行失敗了,代碼我注釋掉了,如果大家能看出來哪里錯(cuò)了的話,希望能告訴我一樣。這里我只是用了最笨的方法

運(yùn)行實(shí)例

scores.csv

在這里插入圖片描述

data.csv

在這里插入圖片描述

控制臺

控制臺

到此這篇關(guān)于Python數(shù)據(jù)處理csv的簡單應(yīng)用的文章就介紹到這了,更多相關(guān)Python數(shù)據(jù)處理csv內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • python shell根據(jù)ip獲取主機(jī)名代碼示例

    python shell根據(jù)ip獲取主機(jī)名代碼示例

    這篇文章主要介紹了python shell根據(jù)ip獲取主機(jī)名代碼示例,涉及用socket模塊和shell中hostname命令獲取等相關(guān)內(nèi)容,具有一定參考價(jià)值,需要的朋友可以了解下。
    2017-11-11
  • python 函數(shù)傳參之傳值還是傳引用的分析

    python 函數(shù)傳參之傳值還是傳引用的分析

    這篇文章主要介紹了python 函數(shù)傳參之傳值還是傳引用的分析,需要的朋友可以參考下
    2017-09-09
  • 解決yum對python依賴版本問題

    解決yum對python依賴版本問題

    這篇文章主要介紹了解決yum對python依賴版本問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-07-07
  • python畫柱狀圖--不同顏色并顯示數(shù)值的方法

    python畫柱狀圖--不同顏色并顯示數(shù)值的方法

    今天小編就為大家分享一篇python畫柱狀圖--不同顏色并顯示數(shù)值的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-12-12
  • python3.7.2 tkinter entry框限定輸入數(shù)字的操作

    python3.7.2 tkinter entry框限定輸入數(shù)字的操作

    這篇文章主要介紹了python3.7.2 tkinter entry框限定輸入數(shù)字的操作,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-05-05
  • 基于Python繪制三種不同的中國結(jié)

    基于Python繪制三種不同的中國結(jié)

    馬上就要迎來新年了,就繪制了幾個(gè)中國結(jié),嘿嘿!本文為大家整理了三個(gè)繪制中國結(jié)的方法,文中的示例代碼講解詳細(xì),快跟隨小編一起動手嘗試一下吧
    2023-01-01
  • Python實(shí)現(xiàn)數(shù)據(jù)可視化大屏布局的示例詳解

    Python實(shí)現(xiàn)數(shù)據(jù)可視化大屏布局的示例詳解

    數(shù)據(jù)可視化大屏展示需求無疑是對數(shù)據(jù)分析結(jié)果最好的詮釋,能夠使得別人能夠輕松的就理解我們的數(shù)據(jù)意圖。本文將通過pyecharts模塊來實(shí)現(xiàn),感興趣的可以了解一下
    2022-11-11
  • Pytest?Fixture參數(shù)講解及使用

    Pytest?Fixture參數(shù)講解及使用

    這篇文章主要介紹了Pytest之Fixture參數(shù)詳解及使用,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-01-01
  • python3從網(wǎng)絡(luò)攝像機(jī)解析mjpeg http流的示例

    python3從網(wǎng)絡(luò)攝像機(jī)解析mjpeg http流的示例

    這篇文章主要介紹了python3從網(wǎng)絡(luò)攝像機(jī)解析mjpeg http流的示例,幫助大家更好的理解和使用python,感興趣的朋友可以了解下
    2020-11-11
  • Python基礎(chǔ)教程之裝飾器詳解

    Python基礎(chǔ)教程之裝飾器詳解

    眾所周知,Python裝飾器是一種常見的元編程特性,在本教程中,我們將深入探討Python裝飾器的基本概念、語法及其應(yīng)用,并利用實(shí)際例子加深理解,感興趣的小伙伴快跟隨小編一起了解一下吧
    2023-06-06

最新評論