我做了一些研究,但找不到按照特定顺序(即由特定列表给出)按列排序表(列表)的方法。
我有一个由列表列表组成的表,其中每个子列表代表该行的一行,其每个元素都是该行的列值。
My_table有4列,我需要根据几个选项对表进行排序。 我目前正在按第一列排序,然后按第二列排序,如下所示
My_table=sorted(My_table, key=lambda a: ( a[0], a[1]))
现在我需要先按第一列排序My_table,然后按第三列排序,但第三列(只包含整数)必须根据整数具有特定顺序的特定列表进行排序,例如:custom_list = [3,0,1,2]。 (注意:列表的整数是可以出现在该列中的所有可能值,但并非所有值都必须出现)。
如何应用排序?
答案 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