Python按字母数字字符串列表排序?

时间:2012-05-19 04:42:45

标签: python list sorted

问题在于,我正在使用sorted函数来排列字母数字字符串列表。所述字符串必须以字母分隔。

例如:sortqns(['s1q1', 's10q1', 's1q2', 's10q10', 's10q2'])

def cmpqn(a, b):
    if len(a) > len(b):
      return 1
    if len(a) < len(b):
      return -1
    if len(a) == len(b):
      return 0

def sortqns(qnlist):
    new = sorted(qnlist, cmp=cmpqn) 
    return new

返回['s1q1', 's1q2', 's10q1', 's10q2', 's10q10']

我的问题是排序第二位数字:

sortqns(['s12q1', 's1q2', 's1q1'])

Returns ['s1q2', 's1q1', 's12q1']

而不是:

Returning ['s1q1', 's1q2', 's12q1']

在第一个例子中,如果前两个项目也被交换,我想要的回报将会关闭。

1 个答案:

答案 0 :(得分:5)

列表中的排序算法是稳定的。稳定的排序算法使用相同的密钥保持记录的相对顺序。因此,在你的代码中,当两个元素具有相同的长度时,它们将在结果中出现维持其相对顺序。

我认为以下解决方案很有帮助。

def sortqns(qnlist):
    return sorted(qnlist, key = lambda x: (len(x), x))