Python では、入れ子の構造を単一レベルのリストに変換するための、反復可能リストの浅いリストのフラット化は一般的なタスクです。これを達成するには、さまざまなレベルのパフォーマンスとコードの可読性を備えたいくつかのアプローチがあります。
最初の試行の 1 つは、次のようなネストされたリストの内包表記を伴う可能性があります。
[image for image in menuitem for menuitem in list_of_menuitems]
ただし、これは'menuitem' が外部内包表記の範囲内で定義されていないため、NameError が発生します。
別のオプションは、 reduce 関数:
reduce(list.__add__, map(lambda x: list(x), list_of_menuitems))
このメソッドはリストを平坦化しますが、list(x) 呼び出しを使用して QuerySet オブジェクトをリストに変換することによって読みやすさが妨げられる可能性があります。
効率的でエレガントなメソッドソリューションは itertools モジュール、具体的には itertools.chain によって提供されます。新しいリストを作成せずに、フラット化されたバージョンのデータ構造を反復処理できます。
from itertools import chain list(chain(*list_of_menuitems))
このアプローチでは、項目を新しいリストにコピーする必要がなくなり、オーバーヘッドが削減されます。アンパック演算子 * の使用を回避する、もう少し明示的なバージョンは次のとおりです。
chain = itertools.chain.from_iterable([[1, 2], [3], [5, 89], [], [6]]) print(list(chain)) # [1, 2, 3, 5, 89, 6]
これらの手法は、パフォーマンスと読みやすさのバランスをとりながら浅いリストを平坦化する場合に役立ちます。
以上がPython で浅いリストを効率的にフラット化するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。