我有一个包含一些侦察员信息的排行榜。该信息的结构如下:ID,forname,surname,points
。此信息存储在文件中,但不在文件中。我不想改变这一点。
我希望在更新列表框时(当我调用calcPoints()
函数时),它会根据记录中的点实体从最大点到最小点对侦察员进行排序。以下是我的calcPoints()
方法的代码。
由于
def _calcPoints():
mainWin._leaderboard.delete(0,END)
with open(tempFileName,'a') as ft:
for sc in self._Scouts:
sc._addPoints(-int(sc._getPoints()))
with open(badgeFile,"r") as fb:
lines = fb.readlines()
for line in lines:
if sc._getID() == line.split(":")[0]:
badge = ((line.split(':')[1]).split(',')[0])
if badge == "Core":
sc._addPoints(5)
elif badge == 'Activity':
sc._addPoints(1)
elif badge == 'Challenge':
sc._addPoints(3)
elif badge == 'Activity Pack':
sc._addPoints(5)
ft.write(sc.getInfo() + "\n")
os.remove(leadFile)
with open(leadFile,"a") as f:
with open(tempFileName,"r") as ft:
lines = ft.readlines()
for line in lines:
f.write(line)
os.remove(tempFileName)
mainWin.addScoutsLeaderboard()
return
答案 0 :(得分:2)
只需调用已排序,按每行中最后一个元素points
排序,使用reverse=True
将从高到低排序:
lines = sorted(fb,key=lambda x: float(x.rsplit(":",1)[1]),reverse=True)
不确定数据所在的文件,因此您的文件对象和分隔符应与实际文件匹配,如果您有标题,则需要添加header = next(fb)
。
如果您单独使用这些值,您可能会发现csv模块更适合:
import csv
with open(badgeFile,"r") as fb:
r = csv.reader(fb,delimiter=":")
lines = sorted(r, key=lambda x: float(x[1]), reverse=True)
for fid,fname,sname,pnts in lines:
在旁注中,您只需要在实际需要列表时调用.readlines()
,否则您只需迭代文件对象。