Python--sorted()関数

3810 ワード

sorted()はPythonの初級関数で、仲間たちは使ったことがありますが、sorted()の使い方はどのくらい知っていますか?
内容は主にPythonから来ています.org、興味があれば自分で見てもいいです.以下のコードはPython 3.4.4 Shellで実行する
まず最も一般的な使い方で、配列を直接ソート操作します:
>>>sorted([1,6,5,3,6,8,99,0])
[0, 1, 3, 5, 6, 6, 8, 99]
配列aをソートするにはsorted(a)でもa.sort()でもよいが、両者にはどのような違いがあるのだろうか.
主な違いは2つあります.
  • sorted()関数は配列自体を修正する
    >>> a = [1,6,5,3,6,8,99,0]
    >>> sorted(a)
    [0, 1, 3, 5, 6, 6, 8, 99]
    >>> a
    [1, 6, 5, 3, 6, 8, 99, 0]
    を変更せずlist.sort()はlistを変更します:
    >>> a = [1, 6, 5, 3, 6, 8, 99, 0]
    >>> a.sort()
    >>> a
    [0, 1, 3, 5, 6, 6, 8, 99]
  • list.sort()関数は配列のみを使用し、sorted()は他のデータ構造にも使用できます:
    >>> b = {1:'a',3:'b',7:'d',4:'4',2:'4'}
    >>> sorted(b)
    [1, 2, 3, 4, 7]
    >>> b
    {1: 'a', 2: '4', 3: 'b', 4: '4', 7: 'd'}
    >>> b.sort()
    Traceback (most recent call last):
    File "", line 1, in
    b.sort()
    AttributeError: 'dict' object has no attribute 'sort'
  • 辞書自体が無秩序であるため、ここではsorted()処理後に辞書の順序が変化することに注意してください.Python 3.4.4ではソートしなくてもShell値が順番に表示されます.
    sorted()またはlistを使用するsort()の場合はパラメータを追加できます
    Key
    keyはソートの根拠:
    >>> sorted("I am working in Hefei, Anhui Province".split())
    ['Anhui', 'Hefei,', 'I', 'Province', 'am', 'in', 'working']
    >>> sorted("I am working in Hefei, Anhui Province".split(),key = str.lower)
    ['am', 'Anhui', 'Hefei,', 'I', 'in', 'Province', 'working']
    文を単語に分割してソートするとアルファベットのASCIIコードでソートされますが、key=str.lowerパラメータを追加すると、すべて小文字のASCIIコードでソートされます.
    >>> a = [
    (1,2,3),
    (3,4,2),
    (2,1,7),
    ]
    >>> sorted(a,key = lambda x: x[1])
    [(2, 1, 7), (1, 2, 3), (3, 4, 2)]
    >>> sorted(a,key = lambda x: x[2])
    [(3, 4, 2), (1, 2, 3), (2, 1, 7)]
    >>> sorted(a)
    [(1, 2, 3), (2, 1, 7), (3, 4, 2)]
    のようなメタグループからなる配列は、keyパラメータを使用してどのパラメータでソートするかを決定することができる.
    同様にkey=objectを用いることができる.attributeは、オブジェクトのプロパティによってオブジェクトを並べます.
    前に辞書のソートについて説明しましたが、辞書の直接ソートはキーをソートします.では、値をソートするにはどうすればいいですか.
    >>> b = {1:'a',3:'b',7:'d',4:'c',2:'k'}
    >>> sorted(b)
    [1, 2, 3, 4, 7]
    >>> sorted(b,key = b.__getitem__)
    [1, 3, 4, 7, 2]
    >>> sorted(b.items(),key = lambda a:a[0])
    [(1, 'a'), (2, 'k'), (3, 'b'), (4, 'c'), (7, 'd')]
    >>> sorted(b.items(),key = lambda a:a[1])
    [(1, 'a'), (3, 'b'), (4, 'c'), (7, 'd'), (2, 'k')]
    Operatorモジュール
    Operatorモジュールにはitemgetter,attrgetter,methodcallerの2つのkey関数が用意されており,
    >>> from operator import itemgetter
    >>> a = [
    (1,2,7),
    (3,4,2),
    (2,2,3),
    ]
    >>> sorted(a,key = itemgetter(1))
    [(1, 2, 7), (2, 2, 3), (3, 4, 2)]
    >>> sorted(a,key = itemgetter(1,2))# ,
    [(2, 2, 3), (1, 2, 7), (3, 4, 2)]
    attrgetterはオブジェクトを属性別に配列するために用いられ,methodcallerはクラス内部のある方法の戻り値別にソートするために用いられる.用法同理.
    昇順降順
    >>> sorted(a,key = itemgetter(1),reverse = True)
    [(3, 4, 2), (1, 2, 7), (2, 2, 3)]
    >>> sorted(a,key = itemgetter(1),reverse = False)
    [(1, 2, 7), (2, 2, 3), (3, 4, 2)]

    並べ替えパラメータが同じ2つのメタグループが元の順序で並べられていることに注意してください.