Skip to content
This repository was archived by the owner on May 7, 2023. It is now read-only.

Files

Latest commit

 

History

History
25 lines (20 loc) · 581 Bytes

deep-flatten.md

File metadata and controls

25 lines (20 loc) · 581 Bytes
title type tags cover dateModified
Deep flatten list
snippet
list
recursion
mask-quiet
2020-12-29 19:53:45 +0200

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]