根据特定的有序列表(和其他选项)对表(列表列表)进行排序

时间:2013-05-30 15:23:32

标签: python sorting

我做了一些研究,但找不到按照特定顺序(即由特定列表给出)按列排序表(列表)的方法。

我有一个由列表列表组成的表,其中每个子列表代表该行的一行,其每个元素都是该行的列值。

My_table有4列,我需要根据几个选项对表进行排序。 我目前正在按第一列排序,然后按第二列排序,如下所示

My_table=sorted(My_table, key=lambda a: ( a[0], a[1]))

现在我需要先按第一列排序My_table,然后按第三列排序,但第三列(只包含整数)必须根据整数具有特定顺序的特定列表进行排序,例如:custom_list = [3,0,1,2]。 (注意:列表的整数是可以出现在该列中的所有可能值,但并非所有值都必须出现)。

如何应用排序?

1 个答案:

答案 0 :(得分:3)

也许是这样的?

order_of_3rd = [3,0,1,2]
My_table.sort(key=lambda a: (a[0], order_of_3rd.index(a[2])))

注意:如果您只是将已排序的列表分配回原始列表,您也可以使用inplace list sort