按字母顺序对带有字母数字项目的列表进行排序

时间:2018-09-10 09:00:38

标签: python python-2.7 list sorting alphanumeric

我有一个包含字母数字项目的列表:

['A08', 'A09', 'A02', 'A03', 'A06', 'A07', 'A04', 'A05', 'A15', 'A14', 'A17', 'A16', 'A11', 
 'B01', 'B03', 'B02', 'B05', 'B04', 'B07', 'B06', 'B09', 'B08', 'B16', 'B17', 'B14', 'B15', 
 'C05', 'C06', 'C07', 'C19', 'C13', 'C12', 'C11', 'C10', 'C17', 'C16', 'C15', 'C14', 'C22', 
 'D02', 'D01', 'D09', 'D08', 'D14', 'D10', 'D11', 'D12', 'D15', 'D16', 'D17', 'D13', 
 'E08', 'E09', 'E06', 'E07', 'E04', 'E05', 'E02', 'E03', 'E01', 'E11', 'E10', 'E13', 'E12', 'E15', 'E14', 'E17', 'E16', 
 'F05', 'F04', 'F07', 'F06', 'F01', 'F03', 'F02', 'F09', 'F08', 'F12', 'F13', 'F10', 'F11', 'F16', 'F17', 'F14', 'F15', 
 'G08', 'G09', 'G04', 'G05', 'G06', 'G07']

我正在尝试使用sorted方法以这种顺序对其进行排序:

['A01', 'B01', 'C01',
 'A02', 'B02', 'C02',
 'A03', 'B03', 'C03']

但是我得到的是:

['A01', 'A02', 'A03',
 'B01', 'B02', 'B03',
 'C01', 'C02', 'C03']

我尝试将多个key传递给sorted,但我不太清楚。

我应该使用什么key?还是应该使用其他方法?

1 个答案:

答案 0 :(得分:4)

您需要的是对数字部分进行优先级排序,因此只需创建一个键函数即可产生一个tuple,其中首先是数字部分,然后是字母部分,然后让自然的tuple排序即可。

print(sorted(lst,key = lambda x : (x[1:],x[0])))

只要有偶数个数字(填充零),就不需要将数字部分转换为整数

有了这样的输入:

lst = ['A01', 'A02', 'A03',
 'B01', 'B02', 'B03',
 'C01', 'C02', 'C03']

您得到:

['A01', 'B01', 'C01', 'A02', 'B02', 'C02', 'A03', 'B03', 'C03']

(如果您想保护列表免受空元素的影响,请进行lambda x : (x[1:],x[0]) if x else tuple()),尽管这样会破坏使用格式化元素排序列表的想法)