通过实体值对tkinter中的列表框中的项目进行排序

时间:2015-07-09 08:21:28

标签: python algorithm tkinter listbox records

我有一个包含一些侦察员信息的排行榜。该信息的结构如下: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

1 个答案:

答案 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(),否则您只需迭代文件对象。