functionalpy
Project description
FunctionalPy
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
- Concurrency through
- 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
- Install Orbstack or Docker Desktop. Make sure to complete the full install process before continuing.
- If not installed, install VSCode
- Press this link
- Complete the setup process
- 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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file functionalpy-0.16.0.tar.gz
.
File metadata
- Download URL: functionalpy-0.16.0.tar.gz
- Upload date:
- Size: 29.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 232634a48d22368020e0dcc6dbe28bd1633f4ace044e885ae6d842706945e4cc |
|
MD5 | 8da426d24414140d71cb2e0e58fc428a |
|
BLAKE2b-256 | 541c02e8fd718188f406cfeef24205db0e2586371a7bc07809238912f84bc543 |
File details
Details for the file functionalpy-0.16.0-py3-none-any.whl
.
File metadata
- Download URL: functionalpy-0.16.0-py3-none-any.whl
- Upload date:
- Size: 10.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7bb54231608d423d2baecad1f967ffe83859046056199df052b4d601ea980a16 |
|
MD5 | eabfc0d3c46560a4544e23a27d2d52db |
|
BLAKE2b-256 | 7f7aa5b52fc62c3f3f37e51de643c511d6f6bd81bdd45c2823a4acdec47d5e2b |