Как сгладить один слой списка списка списков в python?

У меня есть структура вида:

lst= [[['A'], ['B'], ['C']], [['A'], ['B'], ['D'], ['E']], [['B'], ['C']]]

Я хочу свернуть самые внутренние слои списков, чтобы получить следующую структуру:

lst= [['A', 'B', 'C'], ['A', 'B', 'D', 'E'], ['B', 'C']]

Я попытался сгладить список, выполнив следующие действия:

[item for sublst in lst for item in sublst]

Но вместо этого все слои свертываются в одномерный список.

Каков самый питонический способ решить эту проблему?

Почему в Python есть оператор "pass"?
Почему в Python есть оператор "pass"?
Оператор pass в Python - это простая концепция, которую могут быстро освоить даже новички без опыта программирования.
Некоторые методы, о которых вы не знали, что они существуют в Python
Некоторые методы, о которых вы не знали, что они существуют в Python
Python - самый известный и самый простой в изучении язык в наши дни. Имея широкий спектр применения в области машинного обучения, Data Science,...
Основы Python Часть I
Основы Python Часть I
Вы когда-нибудь задумывались, почему в программах на Python вы видите приведенный ниже код?
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
Алиса и Боб имеют неориентированный граф из n узлов и трех типов ребер:
Оптимизация кода с помощью тернарного оператора Python
Оптимизация кода с помощью тернарного оператора Python
И последнее, что мы хотели бы показать вам, прежде чем двигаться дальше, это
Советы по эффективной веб-разработке с помощью Python
Советы по эффективной веб-разработке с помощью Python
Как веб-разработчик, Python может стать мощным инструментом для создания эффективных и масштабируемых веб-приложений.
1
0
385
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Вам нужно перебирать подсписки и индексировать их, чтобы получить желаемый результат (но это предполагает, что ваш внутренний список содержит только один элемент):

lst= [[['A'], ['B'], ['C']], [['A'], ['B'], ['D'], ['E']], [['B'], ['C']]]

result = [[y[0] for y in x] for x in lst]
# [['A', 'B', 'C'], ['A', 'B', 'D', 'E'], ['B', 'C']]

При желании вы можете использовать chain.from_iterable из itertools (теперь это обрабатывает любое количество элементов во внутренних списках):

from itertools import chain

lst= [[['A'], ['B'], ['C']], [['A'], ['B'], ['D'], ['E']], [['B'], ['C']]]

result = [list(chain.from_iterable(x)) for x in lst]
Ответ принят как подходящий

Вам нужно сгладить элементыlst, а не саму lst.

Поэтому используйте двойное понимание списка внутри другого понимания списка, где внешнее понимание выполняет итерацию по вашему списку верхнего уровня:

[[item for inner in sublst for item in inner] for sublst in lst]

Поскольку каждый из ваших самых внутренних списков содержит только один элемент, вы также можете использовать индексирование для получения этих значений:

[[inner[0] for inner in sublst] for sublst in lst]

Демо:

>>> lst = [[['A'], ['B'], ['C']], [['A'], ['B'], ['D'], ['E']], [['B'], ['C']]]
>>> [[item for inner in sublst for item in inner] for sublst in lst]
[['A', 'B', 'C'], ['A', 'B', 'D', 'E'], ['B', 'C']]
>>> [[inner[0] for inner in sublst] for sublst in lst]
[['A', 'B', 'C'], ['A', 'B', 'D', 'E'], ['B', 'C']]

Другие вопросы по теме