我正在尝试对一个包含数字和字母的列表进行排序:
names = ["5aG", "6bG", "10cG", "J1", ...]
输出应该是这样的:
['5aG', '5bG', '5aR', '5bR', '6aG', '6bG', '6cG', '6aR', '6bR', '7aG', '7bG', '7aR', '8aG', '8bG', '8aR', '9aG', '9bG', '9aR','10aG', '10bG', '10cG', '10aR', 'J1', 'J2']
字符串的第一个元素始终是5-10之间的数字,紧接着是a-c之间的一个字母,最后还有一个字母("G"或"R")。
此外还有字符串"J1"和"J2"。它们应该永远是最后的两个字符串("J1"在"J2"之前)。
我该如何实现这样的要求呢?我考虑使用lambda函数。
到目前为止,我只是硬编码了一下,但我认为应该有更好的解决方法。
这是我的硬编码版本:
classes = ['5aG', '5bG', '5aR', '5bR', '6aG', '6bG', '6cG', '6aR', '6bR', '7aG', '7bG', '7aR', '8aG', '8bG', '8aR', '9aG', '9bG', '9aR','10aG', '10bG', '10cG', '10aR', 'J1', 'J2']
def s(v):
"""Get index of element in list"""
try:
return classes.index(v)
except ValueError:
return 500
l = ['5bG', '6aG', '6bG', '8aR', '9aG', '9bG', '9aR', '10cG', '10aR', 'J1', 'J2', '5aG', '']
w = sorted( l, key=s)
print(w)
float(num or 'inf')
看起来很巧妙,但并不特别易读,否则就不需要注释了。可以找到一个可用的N
,以允许使用int(num) or N
。使用re
是过度设计,因为元素可以仅通过位置确定。 - holdenwebint('')
会引发错误。相反,我认为在排序对时使用float('inf')
是很自然的。在我看来,使用任意的N
缺乏普适性并阻碍可扩展性。 - Olivier Melançonint('')
的问题就是为什么我选择在自己的尝试中单独处理“J”值的原因。 - holdenweb