Как сделать естественную сортировку по сложному списку в Python3? - PullRequest
1 голос
/ 03 октября 2019

Я могу выполнить естественную сортировку по простому списку или выполнить обычную сортировку по определенному ключу в сложном списке. Мне нужно сделать естественную сортировку по ключу в сложном списке.

Учитывая эту программу:

import re

def atof(text):
    try:
        retval = float(text)
    except ValueError:
        retval = text
    return retval

def natural_keys(text):
    '''
    alist.sort(key=natural_keys) sorts in human order
    http://nedbatchelder.com/blog/200712/human_sorting.html
    (See Toothy's implementation in the comments)
    float regex comes from https://stackoverflow.com/a/12643073/190597
    '''
    return [ atof(c) for c in re.split(r'[+-]?([0-9]+(?:[.][0-9]*)?|[.][0-9]+)', text) ]

alist=[
    "something1",
    "something2",
    "something10.0",
    "something1.25",
    "something1.105"]

alist.sort(key=natural_keys)
print("alist:")
for i in alist: print(i)

from operator import itemgetter

blist=[
    ['a', "something1"],
    ['b', "something2"],
    ['c', "something10.0"],
    ['d', "something1.25"],
    ['e', "something1.105"]]

blist.sort(key=itemgetter(1))
print("\nblist:")
for i in blist: print(i[1])

Я получаю эти результаты:

alist:
something1
something1.105
something1.25
something2
something10.0

blist:
something1
something1.105
something1.25
something10.0
something2

Как можноЯ получаю Blist, чтобы сортировать так же, как Alist?

1 Ответ

1 голос
/ 03 октября 2019

Вы можете использовать lambda вместо itemgetter.

blist.sort(key=lambda x: natural_keys(x[1]))
...