質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.49%
Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

3回答

719閲覧

長さの頻度によるサブリストのソート

Sayre

総合スコア23

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2019/08/22 05:10

編集2019/08/22 05:41

お世話になっております。

例:
a =[['a', 'b', 'c'], ['d', 'e'], ['f', 'g', 'h'], ['d', 'e'], ['i', 'j', 'k', 'l'], ['m', 'n'], ['o']]
aのリスト左から各要素の長さは下記となります。
['a', 'b', 'c'] = 3
['d', 'e'] = 2
['f', 'g', 'h'] = 3
['d', 'e'] = 2
['i', 'j', 'k', 'l'] = 4
['m', 'n'] = 2
['o'] = 1

長さの頻度としては
4,1が1回(['i', 'j', 'k', 'l'],['o'])
3が2回(['a', 'b', 'c'],['f', 'g', 'h'])、
2が3回(['d', 'e'],['d', 'e'],['m', 'n'])、
そしてアルファベットの順番も考量して下記のように出力させたいです。

result = [['i', 'j', 'k', 'l'], ['o'], ['a', 'b', 'c'], ['f', 'g', 'h'], ['d', 'e'], ['d', 'e'], ['m', 'n']]

今のところ、各要素の頻度の数字を出すところまでは出来ましたが、
そこからどうすれば良いのか、またそもそも頻度の数字を使用するべきなのかもよくわかりません。
ご回答よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

tiitoi

2019/08/22 05:21

a がどのような規則で result の順番になったのか追記していただけますでしょうか。
hayataka2049

2019/08/22 05:31

とりあえずpythonのlistとして構文エラーにならない形に修正しといてください。「このフォーマットで保存されているので読み込みから定義しろ」という話かもしれませんが、それはさすがに自分でやってください。
Sayre

2019/08/22 05:42

ご指摘ありがとうございます。 内容修正させていただきました。
guest

回答3

0

ベストアンサー

こんな感じで実現できました。

python

1from collections import Counter 2a =[['a','b','c'],['d','e'],['f','g','h'],['d','e'],['i','j','k','l'],['m','n'],['o']] 3b = Counter([len(aa) for aa in a]) 4# print(b) 5 6result = sorted(a, key=lambda x : (b[len(x)], x)) 7print(result)

※collenctionsのCounterはじめて使いましたが便利ですね

投稿2019/08/22 05:29

編集2019/08/22 05:43
yamap55

総合スコア1376

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2019/08/22 05:37

a = [['d', 'e'], ['d', 'a']] のようなケースがあった場合、ソート後は[['d', 'a'], ['d', 'e']]になっていてほしいはずなので、sorted()内のx[0]のところはxの方が良いと思います。
hayataka2049

2019/08/22 05:39 編集

まあなんというかややっこしいですね。x[0]じゃなくてxなのかなぁという気がします。 あ、かぶった。
yamap55

2019/08/22 05:42

確かにその通りですね。修正致します。ご指摘ありがとうございます。
Sayre

2019/08/22 05:53

早速のご回答ありがとうございます。 collenctionsのCounter勉強になりました。
guest

0

こんな感じでできます。

Python

1import collections 2 3src = [ 4 ['a', 'b', 'c'], ['d', 'e'], ['f', 'g', 'h'], ['d', 'e'], 5 ['i', 'j', 'k', 'l'], ['m', 'n'], ['o'] 6] 7counter = collections.Counter(map(len, src)) 8 9dst = sorted(src, key=lambda s: counter[len(s)]) 10print(dst)

実行結果 Wandbox

[['i', 'j', 'k', 'l'], ['o'], ['a', 'b', 'c'], ['f', 'g', 'h'], ['d', 'e'], ['d', 'e'], ['m', 'n']]

そしてアルファベットの順番も考量して

Pythonのソートは安定ソートなので、
元々アルファベット順に並んでいるのならば考慮する必要は無いです。

もし元の順序がバラバラなのであれば、二回ソートをかけてやります。

Python

1dst = sorted(src, key=最初の要素を取得する関数オブジェクト) 2dst = sorted(dst, key=lambda s: counter[len(s)])

また、list.sortメソッドを使うとインプレースにソートできます。

投稿2019/08/22 05:36

LouiS0616

総合スコア35660

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Sayre

2019/08/22 05:55

ご回答ありがとうございました。 アルファベットに関しても教えていただきありがとうございます。
guest

0

groupby で 長さごとに分類するようにしてみました。
c.py

python3

1from itertools import groupby 2 3src = [ 4 ['a', 'b', 'c'], ['m', 'n'], ['o'], 5 ['d', 'e'], ['f', 'g', 'h'], ['d', 'e'], 6 ['i', 'j', 'k', 'l'], 7] 8 9 10data = sum( 11 sorted( 12 [sorted(list(g), key=lambda x: x[0]) for k, g in groupby(sorted(src, key=lambda x: len(x)), key=lambda x: len(x))], 13 key= lambda x: (len(x), x[0])), 14 [] 15 ) 16print(data) 17 18print() 19for k, g in groupby(sorted(src, key=lambda x: len(x)), key=lambda x: len(x)): 20 print(k,sorted(list(g), key=lambda x: x[0])) 21 22print() 23g = [sorted(list(g), key=lambda x: x[0]) for k, g in groupby(sorted(src, key=lambda x: len(x)), key=lambda x: len(x))] 24print(g) 25 26print() 27g = sorted(g, key=lambda x: [len(x), x[0][0]]) 28print(g) 29 30print() 31print(sum(g, []))

実行例
イメージ説明

投稿2019/08/23 23:51

編集2019/08/24 01:27
katoy

総合スコア22324

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Sayre

2019/08/28 04:10

回答ありがとうございます。 様々なやりかたがあるんですね、勉強になりました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.49%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問