Skip to main content

functionalpy

Project description

FunctionalPy

Open in Dev Container PyPI Python Version Tests

ALPHA: APIs can change dramatically without notice.

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 🔥:

result = (Seq([1,2,3])
            .map(multiply_by_2)
            .filter(is_even))

Instead of this:

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

Or this:

result = filter(is_even, map(multiply_by_2, [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]

Prior art

FunctionalPy stands on the shoulders of Scala, Rust etc.

Other Python projects have had similar ideas:

  • 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.
  • flupy is highly similar, well typed, and mature. I had some issues with .flatten() not being type-hinted correctly, but at the current level of maturity, flupy is likely a better library.
  • Your library here? Feel free to make an issue if you have a good alternative!

Contributing

Conventions

Philosophy

  • Make it work: Concise syntax borrowed from Scala, Rust etc.
  • Make it right: Fully typed, no exceptions
  • Make it fast:
    • Concurrency through .pmap
    • (Future): Caching
    • (Future): Refactor operations to use generators
  • Keep it simple: No dependencies

API design

As a heuristic, we follow the APIs of:

In cases where this conflicts with typical python implementations, the API should be as predictable as possible for Python users.

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

Uploaded Source

Built Distribution

functionalpy-0.17.0-py3-none-any.whl (10.7 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for functionalpy-0.17.0.tar.gz
Algorithm Hash digest
SHA256 043b5a29eac96759118b35be146354479e1d9f0e2341aae11e5d44f369e38ce2
MD5 60a5f98d92720e2f19c8a76c8990013d
BLAKE2b-256 ec17d65c5cbdf83ab7debf3c9c8bf17a2d02371fa45ed851b8a69671d62096fd

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for functionalpy-0.17.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6b4d53478890f20ac6efb45336196665de049f3f589cd9fa2c5bab15142cfe07
MD5 ef3d0e474e9052ea217846a52abde890
BLAKE2b-256 ae57c5cee2fb339f09f1d5562ce1ea23df8065564c82ea1f6eeb9dcefa4b5ff9

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