Skip to content

A curated list of awesome things related to functional programming in Python.

Notifications You must be signed in to change notification settings

hcholm/awesome-functional-python

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 

Repository files navigation

Awesome Functional Python

A curated list of awesome things related to functional programming in Python.

Awesome

Official documentation

  • Functional Programming HOWTO - "In this document, we’ll take a tour of Python’s features suitable for implementing programs in a functional style".

Books

Free books / ebooks

Non-free books

Talks

Introductory

  • Functional Programming with Python (slides) - Alexey Kachayev, UA PYCon 2012.
  • Purely Functional Programming in Python: Pure Fun (slides) - Christopher Armstrong, PyTenessee 2015.
  • Side Effects are a Public API (video) - Christopher Armstrong, Strangeloop 2015
  • Functional Programming with Python (video) - Mike Müller, PyCon US 2013.
  • Using Functional Programming for efficient Data Processing and Analysis (video) - Reuben Cummings, PyCon US 2017.
  • Immutable Programming Writing Functional Python (slides, video), Calen Pennington, PyCon 2017.
  • Functional Programming inside OOP? It’s possible with Python (Slides) - Carlos Villavicencio, EuroPython 2021.
  • A Hitchhiker’s Guide to functools (Slides) - Scott Irwin, EuroPython 2021.
  • Writing Functional Code in Python (Video) - Vic Kumar, PyCon 2022

Advanced or specialized

  • Functionalish programming in Python with effect (video), Robert Collins, NZ PyCon 2015.
  • Monadic Parsing in Python (slides), Alexey Kachayev, KyivPy 2014.
  • Immutability and Python - Introducing Pyrsistent (slides), Tobias Gustafsson, 2014.
  • Understanding Transducers (slides, video), Austin Bingham, PyCon Belarus 2015.

Data science oriented

  • Functional Performance with Core Data Structures (video), Matthew Rocklin, PyData SV 2014.
  • Old School - Functional Data Analysis (video), Matthew Rocklin, PyData NYC 2013.
  • Learning Data Science Using Functional Python (video, slides), Joel Grus, PyData Seattle 2015.

Other resources

Video lectures (not free)

Blog posts

Scientific papers

Presentation slides

Libraries

General

  • toolz ★4419 - "A functional standard library for Python".
  • fn.py ★3317 - "Functional programming in Python: implementation of missing features to enjoy FP" (unmaintained since 2014). Maintained fork.
  • more-itertools ★3305 - "More routines for operating on iterables, beyond itertools".
  • funcy ★3201 - "A fancy and practical functional tools".
  • PyFunctional ★2272 - "Python library for functional programming with collections in a data pipeline style".
  • Pipe ★1795 - "A Python library to use infix notation in Python".
  • Pydash ★1207 - "The kitchen sink of Python utility libraries for doing "stuff" in a functional way. Based on the Lo-Dash Javascript library".
  • hask ★849 - "Haskell language features and standard libraries in pure Python".
  • OSlash ★699 - "Functors, Applicatives, And Monads in Python".
  • Effect ★363 - "Effect isolation in Python, to facilitate more purely functional code".
  • Expression ★353 - "Pragmatic functional programming for Python inspired by F#". Successor of OSlash.
  • Underscore.py ★291 - "A Python port of excellent javascript library underscore.js".
  • fnc ★218 - "Functional programming in Python with generators and other utilities".
  • Flupy ★178 - Implements a fluent interface for operating on python iterables.
  • pfun ★142 - "Pure functional programming in python".
  • Phi ★130 - "A library that intends to remove as much of the pain as possible from your functional programming experience in Python."
  • pyramda ★126 - "Python package supporting heavy functional programming through currying. Translation of the Ramda library from javascript to python".
  • PyMonad - "a small library implementing monads and related data abstractions -- functors, applicative functors, and monoids -- for use in implementing functional style programs".
  • unpythonic ★82 - "Supercharge your Python with parts of Lisp and Haskell."
  • ziopy ★69 - "ZIO for Python (with ZIO = A type-safe, composable library for async and concurrent programming in Scala)"
  • pyMonet ★34 - "High abstract python library for functional programming. Contains algebraic data structures known from Haskell or Scala".
  • pyeffects ★25 - "Handle side-effects in Python like a boss. Implements functional types for Either, Option, Try, and Future."
  • Iter ★4 - map, filter etc. as methods on a sequence.

Return types

  • returns ★3053 - "Make your functions return something meaningful, typed, and safe!"
  • result ★1189 - A simple Rust like Result type for Python 3. Fully type annotated.
  • Option ★71 - Rust-like Option and Result types in Python.
  • Meiga ★68 - A simple, typed and monad-based Result type for Python.
  • Safetywrap ★40 - Fully typesafe, Rust-like Result and Option types for Python.

Immutable / persistent data structures

  • Pyrsistent ★1940 - "Persistent/Immutable/Functional data structures for Python".
  • Immutables ★1085 - "An immutable mapping type for Python."
  • Discodb ★97 - "An efficient, immutable, persistent mapping object".
  • Funktown ★74 - "Immutable Data Structures for Python".
  • Amino ★35 - "functional data structures and type classes".
  • Pysistence - "Pysistence is a project that seeks to make functional programming in python easier".

Pattern matching

Note: Pattern matching is now a standard feature in Python 3.10.

  • pampy ★3496 - "Pampy: The Pattern Matching for Python you always dreamed of."
  • python-pattern-matching ★159 - "Python pattern matching like functional languages."
  • patmat ★31 - "Functional-style recursive pattern matching in Python. Crazy stuff."
  • apm ★106 - "Pattern Matching for Python 3.8+ in a simple, yet powerful, extensible manner."

Tranducers

  • Tranducers-Python ★202 - "Transducers are composable algorithmic transformations".
  • Transducers ★56 - "This is a port of the transducer concept from Clojure to Python, with an emphasis on providing as Pythonic as interpretation of transducers as possible, rather than reproducing Clojurisms more literally".

Support for reactive style

  • RxPy ★4603 - "Reactive Extensions for Python".
  • broqer ★70 - "Library to operate with continuous streams of data in a reactive style"
  • sodium-python ★3 - "Python implementation of Sodium - Functional Reactive Programming (FRP) Library"

Lenses and declarative data manipulations

  • Glom ★1778 - "Python's nested data operator (and CLI), for all your declarative restructuring needs.".
  • python-lenses ★289 - "A python lens library for manipulating deeply nested immutable structures".

Other / specialized

  • deal ★648 - "Design by contract for Python with many validators support."
  • chainable ★178 - "Method chaining built on generators".
  • ADT ★165 - Algebraic data types for Python
  • sumtypes ★41 - "Sum Types, aka Tagged Unions, for Python".
  • py-frm ★1 - "Proof-of-concept Functional-Relational Mapping (FRM) for Python"
  • python-mini-lambda ★13 - "Simple Lambda functions without lambda x: and with string conversion capability"
  • Orinoco ★11 - "Functional composable pipelines allowing clean separation of the business logic and its implementation"
  • slist ★10 - "A drop-in replacement for the python mutable list. But with much more methods for typesafe method chaining."

Languages

Functional programming languages that are not Python but are related to the Python ecosystem:

  • Hy - "A dialect of Lisp that's embedded in Python".
  • Coconut - "Simple, elegant, Pythonic functional programming".
  • Mochi ★915 - "A dynamically typed programming language for functional programming and actor-style programming.".
  • Tydy ★53 - "Tydy is a statically typed, functional-first programming language in the ML tradition. tydy is an implementation of Tydy as a Python library."
  • dg (aka dogelang) - "A programming language that compiles to CPython bytecode, much like Scala compiles to JVM's. That essentially means that dg is an alternative syntax for Python 3."
  • pixie ★2330 - "A lightweight and native lisp built in RPython". (Discussion on HN)
  • Pycket ★251 - "A rudimentary Racket implementation using RPython".
  • (How to Write a (Lisp) Interpreter (in Python)) and (An ((Even Better) Lisp) Interpreter (in Python)) - a couple of famous articles by Peter Norvig.

More languages that compile to Python.

About

A curated list of awesome things related to functional programming in Python.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published