23

PythonのPHPnatsort関数に似たものがあるかどうか知りたいですか?

l = ['image1.jpg', 'image15.jpg', 'image12.jpg', 'image3.jpg']
l.sort()

与える:

['image1.jpg', 'image12.jpg', 'image15.jpg', 'image3.jpg']

しかし、私は取得したい:

['image1.jpg', 'image3.jpg', 'image12.jpg', 'image15.jpg']

アップデート

このリンクのソリューションベース

def try_int(s):
    "Convert to integer if possible."
    try: return int(s)
    except: return s

def natsort_key(s):
    "Used internally to get a tuple by which s is sorted."
    import re
    return map(try_int, re.findall(r'(\d+|\D+)', s))

def natcmp(a, b):
    "Natural string comparison, case sensitive."
    return cmp(natsort_key(a), natsort_key(b))

def natcasecmp(a, b):
    "Natural string comparison, ignores case."
    return natcmp(a.lower(), b.lower())

l.sort(natcasecmp);
4

3 に答える 3

50

私の答えから自然ソートアルゴリズムへ:

import re
def natural_key(string_):
    """See https://blog.codinghorror.com/sorting-for-humans-natural-sort-order/"""
    return [int(s) if s.isdigit() else s for s in re.split(r'(\d+)', string_)]

例:

>>> L = ['image1.jpg', 'image15.jpg', 'image12.jpg', 'image3.jpg']
>>> sorted(L)
['image1.jpg', 'image12.jpg', 'image15.jpg', 'image3.jpg']
>>> sorted(L, key=natural_key)
['image1.jpg', 'image3.jpg', 'image12.jpg', 'image15.jpg']

Unicode文字列をサポートする.isdecimal()には、の代わりにを使用する必要があり.isdigit()ます。@phihagのコメントの例を参照してください。関連:Unicodeの数値プロパティを明らかにする方法

.isdigit()int()一部のロケールでは、Python 2のバイト文字列が失敗する(戻り値が受け入れられない)場合があります。たとえば、 Windowsのcp1252ロケールでは'\ xb2'('²')です。

于 2010-06-13T18:11:14.173 に答える
17

PyPIでサードパーティのnatsortライブラリを確認できます。

>>> import natsort
>>> l = ['image1.jpg', 'image15.jpg', 'image12.jpg', 'image3.jpg']
>>> natsort.natsorted(l)
['image1.jpg', 'image3.jpg', 'image12.jpg', 'image15.jpg']

完全開示、私は著者です。

于 2013-08-24T05:41:05.730 に答える
2

この関数は、Python2.xおよび3.xのkey=引数として使用できます。sorted

def sortkey_natural(s):
    return tuple(int(part) if re.match(r'[0-9]+$', part) else part
                for part in re.split(r'([0-9]+)', s))
于 2012-05-21T13:24:20.627 に答える