使用2个键进行排序并将两者结合使用

时间:2013-03-12 15:34:32

标签: python list sorting python-3.x indexing

我有一个名为“name_score_smiles.csv”的文件,如下所示:

('VA00001', '64.11', '33.12', 'Cl.O=C1Nc2ccc(N)cc2C1')
('VA00002', '70.61', '54', 'CNCCC(=O)c1ccccc1')
('VA00003', '53.15', '57.76', 'O=c1[nH]c2cnccc2n1c1ccccc1')
('VA00004', '72.08', '41.82', 'CN1CCC(CC1)Nc1ccc(F)c(Cl)c1')
('VA00005', '67.11', '57.17', 'CCN1CCC(CC1)Nc1ccc(Cl)cc1')
('VA00006', '66.29', '48.66', 'O=C1Nc2cc3OCCOc3cc2C(C1)c1ccccc1')
('VA00007', '70.59', '40.31', 'C=CCC1(CCCCC1)NCCc1ccccc1')
('VA00008', '62.87', '43.29', 'Clc1cccc(CN2CCN(CC2)Cc2c[nH]c3ccccc23)c1')
('VA00009', '70.53', '27.3', 'Clc1cccc(CNCCc2c[nH]c3ccccc23)c1')
('VA00010', '67.15', '51.88', 'O=C(Nc1ccccc1)N1CCCCC1c1cccnc1')
...

我已将其作为列表列表阅读,并且我知道如何根据第二列或第三列对此文件进行排序。到目前为止我的脚本看起来像这样:

with open('name_score_smiles.csv') as fin:
        lst = list(csv.reader(fin))

lst_20 = sorted(lst, key=lambda x:float(x[1]), reverse=True)

我想做的是: 我想根据第二列对列表进行排序并保存排名。然后根据第三列对其进行排序并保存排名。因此,最后我可以根据两列中的排名对整个文件进行排序。我的意思是明确的吗?

感谢大家的回答!!

1 个答案:

答案 0 :(得分:2)

通常你会使用tuple或其他一些序列作为这样的排序键:

sorted(lst, key=lambda x: (float(x[1]),float(x[2])), reverse=True)

在排序结束时,您将通过降序列2对您的物品进行排序。如果第2列中的值相等,则将使用第3列的比较。