中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python如何數據處理csv的應用

發布時間:2022-01-11 09:00:52 來源:億速云 閱讀:150 作者:iii 欄目:開發技術

今天小編給大家分享一下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

Python如何數據處理csv的應用

data.csv

Python如何數據處理csv的應用

控制臺

Python如何數據處理csv的應用

以上就是“Python如何數據處理csv的應用”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

黄石市| 满城县| 文登市| 峨眉山市| 兴城市| 泰兴市| 宁国市| 左权县| 昌平区| 义乌市| 庄浪县| 二连浩特市| 宁化县| 嘉黎县| 资中县| 北辰区| 南郑县| 马尔康县| 鹿泉市| 藁城市| 额济纳旗| 吉林省| 怀仁县| 平安县| 宣恩县| 淮安市| 长丰县| 迁西县| 连平县| 嫩江县| 达州市| 阳信县| 外汇| 峡江县| 延庆县| 政和县| 富裕县| 特克斯县| 宣恩县| 德保县| 巩留县|