Skip to main content

Personally common and useful Python features

Project description

kaparoo-python

PyPI version Downloads Python License: MIT uv Ruff ty Copier

Personally common and useful Python features.

📦 Installation

Requires Python 3.14+.

# With uv (recommended)
uv add kaparoo-python

# With pip
pip install kaparoo-python

🧩 Modules

Each submodule ships its own README with focused examples.

kaparoo.filesystem

pathlib-based filesystem helpers: existence checks (*_exists), ensure_* validators, make_dir(s) (with a destructive clean reset option), dir_empty(s), reserve_path(s) guards for not-yet-existing destinations, StagedFile / StagedDirectory for safe (atomic) writes, path stringification, and a small exception hierarchy.

kaparoo.filesystem.search

Filesystem traversal with composable filters. Includes search_paths / search_files / search_dirs, a Filter family (pattern, multi-pattern, logical) that round-trips through JSON-friendly dicts, and an extension hook for custom filter kinds.

kaparoo.utils

Timer / SegmentTimer context-manager-and-decorator timers (with lap-split and measure-block timings); Aggregator for nested, pluggable metric aggregation (the batch → epoch → run pattern); plus a small family of helpers for working with Optional[T] values (replace_if_none, unwrap_or_default, ...).

kaparoo.data

Building blocks for dataset code: DataSequence[T, M] ABC (item + metadata), composers (SlicedSequence, ConcatSequence, WindowedSequence), file-backed templates (FileFolderSequence, SingleFileSequence), and generate_batches.

🎯 Quick example

from kaparoo.filesystem import search_files
from kaparoo.filesystem.search.filters import And, EndsWith, Equals, Not

# All .py files except __init__.py
py_files = search_files(
    "src",
    name_filter=And((EndsWith(".py"), Not(Equals("__init__.py")))),
)

See each submodule's README for more.

📋 TODO

See TODO.md for tracked open items.

📜 Changelog

See CHANGELOG.md for the version history.

⚖️ License

This project is distributed under the terms of the MIT license.

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

kaparoo_python-0.5.0.tar.gz (50.3 kB view details)

Uploaded Source

Built Distribution

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

kaparoo_python-0.5.0-py3-none-any.whl (52.1 kB view details)

Uploaded Python 3

File details

Details for the file kaparoo_python-0.5.0.tar.gz.

File metadata

  • Download URL: kaparoo_python-0.5.0.tar.gz
  • Upload date:
  • Size: 50.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for kaparoo_python-0.5.0.tar.gz
Algorithm Hash digest
SHA256 75b134779c47e8bfaff55ac8965dcdddcaa885d379cb8bf3643c2469af5335a1
MD5 706285ebf130fd93ff8866a829da63a6
BLAKE2b-256 6a38db9aeca10abdff2b028dd8df9d3bc33a51a88cbb64b514434c3e57f0cb0f

See more details on using hashes here.

Provenance

The following attestation bundles were made for kaparoo_python-0.5.0.tar.gz:

Publisher: publish.yml on kaparoo/kaparoo-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file kaparoo_python-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: kaparoo_python-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 52.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for kaparoo_python-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8f3675a3947ed00a95e1e954f4375e6135532f39a7c960c00060f9396a959ca2
MD5 58d9d29504f5ba4d18939d5f186fb2e9
BLAKE2b-256 445e6c9359cf8a41051006286f9292e57b734cdae2819694a9c1c7b3f94cc303

See more details on using hashes here.

Provenance

The following attestation bundles were made for kaparoo_python-0.5.0-py3-none-any.whl:

Publisher: publish.yml on kaparoo/kaparoo-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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