Files
30-seconds-of-code/snippets/deep_flatten.md
Isabelle Viktoria Maciohsek cbc78ee450 Bake dates into snippets
2021-06-13 19:38:10 +03:00

591 B

title, tags, firstSeen, lastUpdated
title tags firstSeen lastUpdated
deep_flatten list,recursion,intermediate 2018-01-16T16:54:14+02:00 2020-12-29T19:53:45+02:00

Deep flattens a list.

  • Use recursion.
  • Use isinstance() with collections.abc.Iterable to check if an element is iterable.
  • If it is iterable, apply deep_flatten() recursively, otherwise return [lst].
from collections.abc import Iterable

def deep_flatten(lst):
  return ([a for i in lst for a in
          deep_flatten(i)] if isinstance(lst, Iterable) else [lst])
deep_flatten([1, [2], [[3], 4], 5]) # [1, 2, 3, 4, 5]