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
  • Keep it simple: No dependencies

Prior art

FunctionalPy stands on the shoulders of Scala, Rust etc.

Moreover, PyFunctional has existed for 7+ years with a comprehensive feature set. It is performant, with built-in lineage and caching. Unfortunately, this makes typing non-trivial, with a 4+ year ongoing effort to add types.

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.14.0.tar.gz (25.6 kB view details)

Uploaded Source

Built Distribution

functionalpy-0.14.0-py3-none-any.whl (9.7 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for functionalpy-0.14.0.tar.gz
Algorithm Hash digest
SHA256 ebddbfe2018aff813442a6727600a29913cd16aa7191ae30413079d2941417f6
MD5 901bdfcc8e389f454a256f26e0ab8f05
BLAKE2b-256 58fef21539e21071fadb6bc6bd361eb74e5dfb71580634255469d5801b81d1e4

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for functionalpy-0.14.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c9784c7080e757a59aaf41b9121e11b188cdbf0fb262c172986962653145b617
MD5 d4c9cd59ee7045d9cc242ba34da41934
BLAKE2b-256 ed54f511845dde1b04213744ca892c5e1a30202de675a492e4dbba618db6ff73

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