Skip to main content

functionalpy

Project description

FunctionalPy

Open in Dev Container PyPI Python Version Tests

Python has implemented map, filter etc. as functions, rather than methods on a sequence. This makes the result harder to read and Iterators less used than they could be. FunctionalPy exists to change that.

You get 🔥🔥🔥this🔥🔥🔥:

Seq([1,2,3])
   .map(lambda x: multiply_by_2(x))
   .filter(lambda x: is_even(x))

Instead of this:

sequence = [1,2,3]
multiplied = [multiply_by_2(x) for x in sequence]
is_even = [x for x in multiplied if is_even(x)]

Or this:

filter(lambda x: is_even(x), map(lambda x: multiply_by_2(x), [1,2,3]))

Install

pip install functionalpy

Usage

from functionalpy import Seq

result = (Seq([1, 2])
            .filter(lambda x: x % 2 == 0)
            .map(lambda x: x * 2)
            .to_list()
)
assert result == [4]

Philosophy

  • Make it work: Concise syntax borrowed from Scala, Rust etc.
  • Make it right: Fully typed, no exceptions.
  • Make it fast: Concurrency through .pmap, potentially caching in the future

Prior art

FunctionalPy stands on the shoulders of Scala, Rust etc. Moreover, PyFunctional has existed for 7+ years, bringing most of the functionality to the Python. It definitely helps make it fast, with built-in lineage and caching. Unfortunately, this makes typing non-trivial, and has been going on for 4 years.

Contributing

Devcontainer

  1. Install Orbstack or Docker Desktop. Make sure to complete the full install process before continuing.
  2. If not installed, install VSCode
  3. Press this link
  4. Complete the setup process
  5. Done! Easy as that.

💬 Where to ask questions

Type
🚨 Bug Reports GitHub Issue Tracker
🎁 Feature Requests & Ideas GitHub Issue Tracker
👩‍💻 Usage Questions GitHub Discussions
🗯 General Discussion GitHub Discussions

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

functionalpy-0.13.0.tar.gz (24.5 kB view details)

Uploaded Source

Built Distribution

functionalpy-0.13.0-py3-none-any.whl (9.8 kB view details)

Uploaded Python 3

File details

Details for the file functionalpy-0.13.0.tar.gz.

File metadata

  • Download URL: functionalpy-0.13.0.tar.gz
  • Upload date:
  • Size: 24.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.6

File hashes

Hashes for functionalpy-0.13.0.tar.gz
Algorithm Hash digest
SHA256 60ae1ae62e7e1cd2ae8720bade6a4221676abbae9ef2dcbcf48ea365d7430696
MD5 1f81d228a1714d3edc6b879cb045b4ba
BLAKE2b-256 aa84873063547057c1bd27d4f17affa01b8e06e311846f2f93735f6c5ccfecd5

See more details on using hashes here.

File details

Details for the file functionalpy-0.13.0-py3-none-any.whl.

File metadata

File hashes

Hashes for functionalpy-0.13.0-py3-none-any.whl
Algorithm Hash digest
SHA256 08e477d5f9c9f61274eb699240b4c19b78f3ae3b99975a52369b69795b388fcc
MD5 cf7854fe1d405fa5ae363d77103e67b5
BLAKE2b-256 1590cd424570b78f187a9135fc2c1e23eb0a45b7722288aaa341969b9fe64bac

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page