リストのリストを交互に並べ替える
形式 [['a',1], [' のサブリストを含むリストが与えられたとします。 a',2]、['a',3]、['b',1]、['b',2]、['b',3]]、目標は、これらのサブリストを交互に並べ替えることです。 、要素 0 は降順でソートされ、要素 1 は昇順でソートされます。予期される結果は [['b',1]、['b',2]、['b',3]、['a',1]、['a',2]、['a'、 3]].
これを実現するには、カスタム キーを使用して sort() 関数を利用できます。重要なのは、対象の要素を抽出し、それらに並べ替え操作を適用するラムダ関数です。この場合、各サブリストの最初の要素を取得し、降順ソートを適用して、それを昇順でソートされた 2 番目の要素の負の要素と結合します。 reverse=True でソート順序を逆にすると、サブリストは最初の要素で降順、2 番目の要素で昇順にソートされます。これにより、望ましい交互順序が得られます。
次のコード スニペットは、解決策を示しています。
<code class="python">L = [['a',1], ['a',2], ['a',3], ['b',1], ['b',2], ['b',3]] L.sort(key=lambda k: (k[0], -k[1]), reverse=True) print(L) # [['b', 1], ['b', 2], ['b', 3], ['a', 1], ['a', 2], ['a', 3]]</code>
以上がPythonでリストのリストを交互の順序で並べ替える方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。