Stouputils is a collection of utility modules designed to simplify and enhance the development process. It includes a range of tools for tasks such as execution of doctests, display utilities, decorators, as well as context managers, and many more.
Project description
๐ ๏ธ Project Badges
๐ Project Overview
Stouputils is a collection of utility modules designed to simplify and enhance the development process.
It includes a range of tools for tasks such as execution of doctests, display utilities, decorators, as well as context managers.
Start now by installing the package: pip install stouputils.
๐ CLI Quick Reference
Stouputils provides a powerful command-line interface. Here's a quick example for each subcommand:
# Show version information of polars with dependency tree of depth 3
stouputils --version polars -t 3
# Run all doctests in a directory with pattern filter (fnmatch)
stouputils all_doctests "./src" "*_test"
# Repair a corrupted/obstructed zip archive
stouputils repair "./input.zip" "./output.zip"
# Create a delta backup
stouputils backup delta "./source" "./backups"
# Build and publish to PyPI (with minor version bump and no stubs)
stouputils build minor --no_stubs
# Generate changelog from git history (since a specific date, with commit URLs from origin remote, output to file)
stouputils changelog date "2026-01-01" -r origin -o "CHANGELOG.md"
# Redirect (move) a folder and create a junction/symlink at the original location
stouputils redirect "C:/Games/MyGame" "D:/Games/" --hardlink
๐ See the Extensive CLI Documentation section below for detailed usage and all available options.
๐ Project File Tree
<style> .code-tree { border-radius: 6px; padding: 16px; font-family: monospace; line-height: 1.45; overflow: auto; white-space: pre; background-color:rgb(43, 43, 43); color: #d4d4d4; } .code-tree a { color: #569cd6; text-decoration: none; } .code-tree a:hover { text-decoration: underline; } .code-tree .comment { color:rgb(231, 213, 48); } .code-tree .paren { color: orange; } </style>
stouputils/ โโโ print # ๐จ๏ธ Utility functions for printing (info, debug, warning, error, whatisit, breakpoint, colored_for_loop, ...) โโโ decorators # ๐ฏ Decorators (measure_time, handle_error, timeout, retry, simple_cache, abstract, deprecated, silent) โโโ ctx # ๐ Context managers (LogToFile, MeasureTime, Muffle, DoNothing, SetMPStartMethod) โโโ io # ๐พ Utilities for file management (json_dump, json_load, csv_dump, csv_load, read_file, super_copy, super_open, clean_path, redirect_folder, ...) โโโ parallel # ๐ Utility functions for parallel processing (multiprocessing, multithreading, run_in_subprocess) โโโ image # ๐ผ๏ธ Little utilities for image processing (image_resize, auto_crop, numpy_to_gif, numpy_to_obj) โโโ collections # ๐งฐ Utilities for collection manipulation (unique_list, at_least_n, sort_dict_keys, upsert_in_dataframe, array_to_disk) โโโ typing # ๐ Utilities for typing enhancements (IterAny, JsonDict, JsonList, ..., convert_to_serializable) โโโ all_doctests # โ Run all doctests for all modules in a given directory (launch_tests, test_module_with_progress) โโโ backup # ๐พ Utilities for backup management (delta backup, consolidate) โโโ lock # ๐ Inter-process FIFO locks (LockFifo, RLockFifo, RedisLockFifo) โโโ archive # ๐ฆ Functions for creating and managing archives (create, repair) โโโ config # โ๏ธ Global configuration (StouputilsConfig: global options) โ โโโ applications/ โ โโโ automatic_docs # ๐ Documentation generation utilities (used to create this documentation) โ โโโ upscaler # ๐ Image & Video upscaler (configurable) โ โโโ ... โ โโโ continuous_delivery/ โ โโโ cd_utils # ๐ง Utilities for continuous delivery โ โโโ git # ๐ Utilities for local git changelog generation โ โโโ github # ๐ฆ Utilities for continuous delivery on GitHub (upload_to_github) โ โโโ pypi # ๐ฆ Utilities for PyPI (pypi_full_routine) โ โโโ pyproject # ๐ Utilities for reading, writing and managing pyproject.toml files โ โโโ stubs # ๐ Utilities for generating stub files using stubgen โ โโโ ... โ โโโ mlflow/ โ โโโ process_metrics_monitor # ๐ Monitor CPU, memory, I/O, and thread metrics for a specific process tree and log them to MLflow โ โโโ ... โ โโโ installer/ โ โโโ common # ๐ง Common functions used by the Linux and Windows installers modules โ โโโ downloader # โฌ๏ธ Functions for downloading and installing programs from URLs โ โโโ linux # ๐ง Linux/macOS specific implementations for installation โ โโโ main # ๐ Core installation functions for installing programs from zip files or URLs โ โโโ windows # ๐ป Windows specific implementations for installation โ โโโ ... โโโ ...
๐ง Installation
pip install stouputils
โจ Enable Tab Completion on Linux (Optional)
For a better CLI experience, enable bash tab completion:
# Option 1: Using argcomplete's global activation
activate-global-python-argcomplete --user
# Option 2: Manual setup for bash
register-python-argcomplete stouputils >> ~/.bashrc
source ~/.bashrc
After enabling completion, you can use <TAB> to autocomplete commands:
stouputils <TAB> # Shows: --version, -v, all_doctests, backup
stouputils all_<TAB> # Completes to: all_doctests
Note: Tab completion works best in bash, zsh, Git Bash, or WSL on Windows.
๐ Extensive CLI Documentation
The stouputils CLI provides several powerful commands for common development tasks.
โก General Usage
stouputils <command> [options]
Running stouputils without arguments displays help with all available commands.
๐ --version / -v โ Show Version Information
Display the version of stouputils and its dependencies, along with the used Python version.
# Basic usage - show stouputils version
stouputils --version
stouputils -v
# Show version for a specific package
stouputils --version numpy
stouputils -v requests
# Show dependency tree (depth 3+)
stouputils --version -t 3
stouputils -v stouputils --tree 4
Options:
| Option | Description |
|---|---|
[package] |
Optional package name to show version for (default: stouputils) |
-t, --tree <depth> |
Show dependency tree with specified depth (โค2 for flat list, โฅ3 for tree view) |
โ
all_doctests โ Run Doctests
Execute all doctests in Python files within a directory.
# Run doctests in current directory
stouputils all_doctests
# Run doctests in specific directory
stouputils all_doctests ./src
# Run doctests with file pattern filter
stouputils all_doctests ./src "*image/*.py"
stouputils all_doctests . "*utils*"
Arguments:
| Argument | Description |
|---|---|
[directory] |
Directory to search for Python files (default: .) |
[pattern] |
Glob pattern to filter files (default: *) |
Exit codes:
0: All tests passed1: One or more tests failed
๐ฆ archive โ Archive Utilities
Create and repair ZIP archives.
# Show archive help
stouputils archive --help
archive make โ Create Archive
# Basic archive creation
stouputils archive make ./my_folder ./backup.zip
# Create archive with ignore patterns
stouputils archive make ./project ./project.zip --ignore "*.pyc,__pycache__,*.log"
# Create destination directory if needed
stouputils archive make ./source ./backups/archive.zip --create-dir
Arguments & Options:
| Argument/Option | Description |
|---|---|
<source> |
Source directory to archive |
<destination> |
Destination zip file path |
--ignore <patterns> |
Comma-separated glob patterns to exclude |
--create-dir |
Create destination directory if it doesn't exist |
archive repair โ Repair Corrupted ZIP
# Repair with auto-generated output name
stouputils archive repair ./corrupted.zip
# Repair with custom output name
stouputils archive repair ./corrupted.zip ./fixed.zip
Arguments:
| Argument | Description |
|---|---|
<input_file> |
Path to the corrupted zip file |
[output_file] |
Path for repaired file (default: adds _repaired suffix) |
๐พ backup โ Backup Utilities
Create delta backups, consolidate existing backups, and manage backup retention.
# Show backup help
stouputils backup --help
backup delta โ Create Delta Backup
Create an incremental backup containing only new or modified files since the last backup.
# Basic delta backup
stouputils backup delta ./my_project ./backups
# Delta backup with exclusions
stouputils backup delta ./project ./backups -x "*.pyc" "__pycache__/*" "node_modules/*"
stouputils backup delta ./source ./backups --exclude "*.log" "temp/*"
Arguments & Options:
| Argument/Option | Description |
|---|---|
<source> |
Source directory or file to back up |
<destination> |
Destination folder for backups |
-x, --exclude <patterns> |
Glob patterns to exclude (space-separated) |
backup consolidate โ Consolidate Backups
Merge multiple delta backups into a single complete backup.
# Consolidate all backups up to latest.zip into one file
stouputils backup consolidate ./backups/latest.zip ./consolidated.zip
Arguments:
| Argument | Description |
|---|---|
<backup_zip> |
Path to the latest backup ZIP file |
<destination_zip> |
Path for the consolidated output file |
backup limit โ Limit Backup Count
Limit the number of delta backups by consolidating the oldest ones.
# Keep only the 5 most recent backups
stouputils backup limit 5 ./backups
# Allow deletion of the oldest backup (not recommended)
stouputils backup limit 5 ./backups --no-keep-oldest
Arguments & Options:
| Argument/Option | Description |
|---|---|
<max_backups> |
Maximum number of backups to keep |
<backup_folder> |
Path to the folder containing backups |
--no-keep-oldest |
Allow deletion of the oldest backup (default: keep it) |
๐๏ธ build โ Build and Publish to PyPI
Build and publish a Python package to PyPI using the uv tool. This runs a complete routine including version bumping, stub generation, building, and publishing.
# Standard build and publish (bumps patch by default)
stouputils build
# Build without generating stubs and without bumping version
stouputils build --no_stubs --no_bump
# Bump minor version before build
stouputils build minor
# Bump major version before build
stouputils build major
Options:
| Option | Description |
|---|---|
--no_stubs |
Skip stub file generation |
--no_bump |
Skip version bumping (use current version) |
minor |
Bump minor version (e.g., 1.2.0 โ 1.3.0) |
major |
Bump major version (e.g., 1.2.0 โ 2.0.0) |
๐ changelog โ Generate Changelog
Generate a formatted changelog from local git history.
# Show changelog help
stouputils changelog --help
# Generate changelog since latest tag (default)
stouputils changelog
# Generate changelog since a specific tag
stouputils changelog tag v1.9.0
# Generate changelog since a specific date
stouputils changelog date 2026/01/05
stouputils changelog date "2026-01-15 14:30:00"
# Generate changelog since a specific commit
stouputils changelog commit 847b27e
# Include commit URLs from a remote
stouputils changelog --remote origin
stouputils changelog tag v2.0.0 -r origin
# Output to a file
stouputils changelog -o CHANGELOG.md
stouputils changelog tag v1.0.0 --output docs/CHANGELOG.md
Arguments & Options:
| Argument/Option | Description |
|---|---|
[mode] |
Mode for selecting commits: tag, date, or commit (default: tag) |
[value] |
Value for the mode (tag name, date, or commit SHA) |
-r, --remote <name> |
Remote name for commit URLs (e.g., origin) |
-o, --output <file> |
Output file path (default: stdout) |
Supported date formats:
YYYY/MM/DDorYYYY-MM-DDDD/MM/YYYYorDD-MM-YYYYYYYY-MM-DD HH:MM:SS- ISO 8601:
YYYY-MM-DDTHH:MM:SS
๐ redirect โ Redirect a Folder
Move a folder to a new location and create a junction or symlink at the original path. Useful for redirecting game installs, large data folders, etc. across drives.
# Show redirect help
stouputils redirect --help
# Redirect with auto-detected basename (destination ends with /)
stouputils redirect "C:/Games/MyGame" "D:/Games/" --hardlink
# Redirect with explicit destination name
stouputils redirect "C:/Games/MyGame" "D:/Storage/MyGame" --symlink
# Interactive mode (asks for link type)
stouputils redirect "./my_folder" "/mnt/external/"
Arguments & Options:
| Argument/Option | Description |
|---|---|
<source> |
Source folder to redirect |
<destination> |
Destination path (append / to auto-use source basename) |
--hardlink / --junction |
Use NTFS junction (Windows) or fallback to symlink (Linux/macOS) |
--symlink |
Use a symbolic link (may need admin on Windows) |
Notes:
- If
--hardlinkfails (e.g., unsupported OS), it automatically falls back to symlink - If the source is already a symlink or junction, the operation is skipped
- On Linux/macOS, junctions are not available so
--hardlinkuses a symlink instead
๐ Examples Summary
| Command | Description |
|---|---|
stouputils -v |
Show version |
stouputils -v numpy -t 3 |
Show numpy version with dependency tree |
stouputils all_doctests ./src |
Run doctests in src directory |
stouputils archive make ./proj ./proj.zip |
Create archive |
stouputils archive repair ./bad.zip |
Repair corrupted zip |
stouputils backup delta ./src ./bak -x "*.pyc" |
Create delta backup |
stouputils backup consolidate ./bak/latest.zip ./full.zip |
Consolidate backups |
stouputils backup limit 5 ./bak |
Keep only 5 backups |
stouputils build minor |
Build with minor version bump |
stouputils changelog tag v1.0.0 -r origin -o CHANGELOG.md |
Generate changelog to file |
stouputils redirect "C:/Games/MyGame" "D:/Games/" --hardlink |
Redirect folder with junction |
โญ Star History
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file stouputils-1.26.4.tar.gz.
File metadata
- Download URL: stouputils-1.26.4.tar.gz
- Upload date:
- Size: 160.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.11 {"installer":{"name":"uv","version":"0.11.11","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ca78bfabbd5252c1e82a897582dd3987ec826cea38a63c4fdb18a9b8e4db4927
|
|
| MD5 |
b8817033789abab4db58496c0b081bc7
|
|
| BLAKE2b-256 |
a6ea420a6ec28aab335d6be513ca5888ecd64528036cb8c36f9f44103ead1c44
|
File details
Details for the file stouputils-1.26.4-py3-none-any.whl.
File metadata
- Download URL: stouputils-1.26.4-py3-none-any.whl
- Upload date:
- Size: 279.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.11 {"installer":{"name":"uv","version":"0.11.11","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5939b7ad78ffc2f13e425a74aef1c1e04ed5176fbf4fecd2d5b08a3b8354770c
|
|
| MD5 |
2a31788bda35f2b0950beb3fbd4aefee
|
|
| BLAKE2b-256 |
66507c1664faa2486584bc972d2bdfb5a7667f96d53bf2917fb19933bddeb638
|