淺談Python數(shù)據(jù)處理csv的應(yīng)用小結(jié)
題目
文件scores.csv包含十位學(xué)生的成績(jī)單,表頭是"姓名 語(yǔ)文 數(shù)學(xué) 英語(yǔ)"。請(qǐng)編程完成下述功能。
1)計(jì)算每位學(xué)生的總分與排名,并將擴(kuò)充后的學(xué)生信息寫(xiě)入文件data.csv中,新文件表頭是"姓名 語(yǔ)文 數(shù)學(xué) 英語(yǔ) 總分 名次";
2)同時(shí),在控制臺(tái)上分行輸出各門(mén)課的最高分與最低分以及對(duì)應(yīng)的學(xué)生姓名,輸出格式為"課程名 :(最高分,學(xué)生1,… ,學(xué)生n),(最低分,學(xué)生1,… ,學(xué)生n)";
3)如果總分相同,則同一名次下可能有多人并列,如果最高分或最低分有多人相同,則將這么多人按字母序先后寫(xiě)在同一個(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)
#語(yǔ)文最高分最低分更新
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])
#英語(yǔ)最高分最低分更新
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("語(yǔ)文:{0},{1}".format(tuple(ChMax),tuple(ChMin)))
print("數(shù)學(xué):{},{}".format(tuple(MaMax),tuple(MaMin)))
print("英語(yǔ):{},{}".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("名次")
#寫(xiě)入data.csv
for row in ls:
fw.write(",".join(row)+"\n")
fr.close()
fw.close()這段代碼是可以正常運(yùn)行的,但是更新最大最小成績(jī),我想把它分裝成一個(gè)函數(shù),但是運(yùn)行失敗了,代碼我注釋掉了,如果大家能看出來(lái)哪里錯(cuò)了的話(huà),希望能告訴我一樣。這里我只是用了最笨的方法
運(yùn)行實(shí)例
scores.csv

data.csv

控制臺(tái)

到此這篇關(guān)于Python數(shù)據(jù)處理csv的簡(jiǎn)單應(yīng)用的文章就介紹到這了,更多相關(guān)Python數(shù)據(jù)處理csv內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python簡(jiǎn)單調(diào)用MySQL存儲(chǔ)過(guò)程并獲得返回值的方法
這篇文章主要介紹了Python調(diào)用MySQL存儲(chǔ)過(guò)程并獲得返回值的方法,涉及Python操作MySQL存儲(chǔ)過(guò)程的使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07
淺談Python中的函數(shù)(def)及參數(shù)傳遞操作
這篇文章主要介紹了淺談Python中的函數(shù)(def)及參數(shù)傳遞操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-05-05
python利用小波分析進(jìn)行特征提取的實(shí)例
今天小編就為大家分享一篇python利用小波分析進(jìn)行特征提取的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-01-01
Python模塊結(jié)構(gòu)與布局操作方法實(shí)例分析
這篇文章主要介紹了Python模塊結(jié)構(gòu)與布局操作方法,結(jié)合實(shí)例形式分析了Python模塊與布局的相關(guān)概念、使用方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下2017-07-07
Python在cmd上打印彩色文字實(shí)現(xiàn)過(guò)程詳解
這篇文章主要介紹了Python在cmd上打印彩色文字實(shí)現(xiàn)過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08

