Skip to main content

Convenient Sequence/Iterable/Collection processing for python. Inspired by Clojure mapping and threading macros.

Project description

trent

Convenient Collection/Sequence/Iterable processing for python.

Inspired by Clojure mapping and threading macros.

Supprot full python12 (and later vesrsion) typing, unlike default map and filter functions. Which allows for production-grade development. Provides some work-around for python typing issues (like inability to filter out types from aggregate type). Provides some auxiliary side funtions, like first, second, nth, getter etc. Also, provide some additional usefull functionality, like group_by and partition_by (see more examples below)

What is it for

Writing functional, fully typehinted code in a style of Common Lisp / Clojure mappings, with convenience of Clojure funcall threading (->, ->>, as-> macroses), but with python native syntax (without trying to force-fit any other syntax in)

And more:

  • Processing Iterables in a functional manner, with lazy evaluation (in most cases)
  • Iterating, concating, grouping and collecting elements of given sequences quickly.
  • Prototyping code in quick, readable and maintanable manner.
  • Writing fully typehinted code (unlike default map/filter)
  • Built-in assyncronous calls (mapping, filtering etc.)
  • Reducing resulting iterables.

What is it NOT for

trent - is keps simple for a reason. Don't try to use it for more than it designed for.

  • Not for high load / high performance Sequences processing (although - it supports parallel-map)
  • Not for processing table-like data. Just use pandas/polars/pyspark for that. trent is more suitable for processing each element individually

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

trent-0.4.6.tar.gz (14.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

trent-0.4.6-py3-none-any.whl (15.0 kB view details)

Uploaded Python 3

File details

Details for the file trent-0.4.6.tar.gz.

File metadata

  • Download URL: trent-0.4.6.tar.gz
  • Upload date:
  • Size: 14.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.13

File hashes

Hashes for trent-0.4.6.tar.gz
Algorithm Hash digest
SHA256 f9267c70e4331479e2c3482e6de10c52f4dd1ba7f67693d2d7a3cc0a68297a38
MD5 68af58600f4a3cecf9a91fb1d93cab9a
BLAKE2b-256 a0d63b064a3f76e76e0736ebe63359125fec25fa2a0dce5721807a9c803b6665

See more details on using hashes here.

File details

Details for the file trent-0.4.6-py3-none-any.whl.

File metadata

  • Download URL: trent-0.4.6-py3-none-any.whl
  • Upload date:
  • Size: 15.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.13

File hashes

Hashes for trent-0.4.6-py3-none-any.whl
Algorithm Hash digest
SHA256 72cd6bd110d77df56878e718df4ea5d7bd16d842357ac25ecf9aa2da711461c0
MD5 69be6033e3014d8c02ef279a40a996db
BLAKE2b-256 8b4c4f8a516fcdf1b5c93f13e7b3edb2729db7565130f6cf5d7c7f522d73427e

See more details on using hashes here.

Supported by

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