我有一个字符串列表,格式如下:
['variable1 (name1)', 'variable2 (name2)', 'variable3 (name3)', ...]
我希望按照字母顺序对列表进行排序,基于(nameX)
这一部分。我该如何做到这一点?
要更改排序键,请使用 key
参数:
>>>s = ['variable1 (name3)', 'variable2 (name2)', 'variable3 (name1)']
>>> s.sort(key = lambda x: x.split()[1])
>>> s
['variable3 (name1)', 'variable2 (name2)', 'variable1 (name3)']
>>>
对于sorted
函数也是同样的工作原理:
>>>s = ['variable1 (name3)', 'variable2 (name2)', 'variable3 (name1)']
>>> sorted(s)
['variable1 (name3)', 'variable2 (name2)', 'variable3 (name1)']
>>> sorted(s, key = lambda x: x.split()[1])
['variable3 (name1)', 'variable2 (name2)', 'variable1 (name3)']
>>>
>>> import re
>>> r = re.compile(r'\((name\d+)\)')
>>> lis = ['variable1 (name1)', 'variable3 (name3)', 'variable2 (name100)']
>>> sorted(lis, key=lambda x:r.search(x).group(1))
['variable1 (name1)', 'variable2 (name100)', 'variable3 (name3)']
请注意,上述代码将返回像name100
这样的内容在name3
之前,如果这不是您想要的,那么您需要执行类似以下的操作:>>> r = re.compile(r'\(name(\d+)\)')
def key_func(m):
return int(r.search(m).group(1))
>>> sorted(lis, key=key_func)
['variable1 (name1)', 'variable3 (name3)', 'variable2 (name100)']
只需使用sort
方法的key
参数:
test.sort(key = lambda x: x.split("(")[1])
编辑: test
是数组。
sorted(b, key = lambda x: x.split()[1])
为什么?我们想要对列表(称为b)进行排序。作为一个键,我们将使用(名称X)。在这里,我们假设它总是在空格之前,因此我们将列表项分成两部分,并根据第二个部分进行排序。
xxx(name2), xxx(name3), xxx(name20)
进行排序? - georg