您好,登錄后才能下訂單哦!
今天小編給大家分享一下Python如何數(shù)據(jù)處理csv的應(yīng)用的相關(guān)知識(shí)點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識(shí),所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
文件scores.csv包含十位學(xué)生的成績單,表頭是"姓名 語文 數(shù)學(xué) 英語"。請編程完成下述功能。
1)計(jì)算每位學(xué)生的總分與排名,并將擴(kuò)充后的學(xué)生信息寫入文件data.csv中,新文件表頭是"姓名 語文 數(shù)學(xué) 英語 總分 名次";
2)同時(shí),在控制臺(tái)上分行輸出各門課的最高分與最低分以及對(duì)應(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í),會(huì)改變其實(shí)參的值(在函數(shù)中若改動(dòng)其值) #但是若不想實(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ò)了的話,希望能告訴我一樣。這里我只是用了最笨的方法
scores.csv
data.csv
控制臺(tái)
以上就是“Python如何數(shù)據(jù)處理csv的應(yīng)用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會(huì)為大家更新不同的知識(shí),如果還想學(xué)習(xí)更多的知識(shí),請關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。