A library for automatically generating command line interfaces.
Project description
Python Water 
Fork of python-fire
I love Fire! But I need some Water.
Python Water is a fork of Google's python-fire with the following additions:
- Auto-casting from type annotations. CLI arguments are automatically cast using Python type hints. Write
def foo(count: int)and Water handles the parsing. SupportsOptional[T],Union, and custom constructors viaregister_type_constructor(). [details]- Type-safe codebase. All source code passes the ty type checker and uses maximized Ruff linting (
select = ["ALL"]).- Async support.
asyncandawaitfunctions are natively supported.- Modernized tooling. Migrated from pylint to Ruff and updated CI workflows.
Migrating from python-fire? See the Migration Guide.
Python Water is a library for automatically generating command line interfaces (CLIs) from absolutely any Python object.
- Python Water is a simple way to create a CLI in Python. [1]
- Python Water is a helpful tool for developing and debugging Python code. [2]
- Python Water helps with exploring existing code or turning other people's code into a CLI. [3]
- Python Water makes transitioning between Bash and Python easier. [4]
- Python Water makes using a Python REPL easier by setting up the REPL with the modules and variables you'll need already imported and created. [5]
Installation
To install Python Water with pip, run: pip install python-water
To install Python Water from source, first clone the repository and then run:
pip install .
Basic Usage
You can call Water on any Python object:
functions, classes, modules, objects, dictionaries, lists, tuples, etc.
They all work!
Here's an example of calling Water on a function.
import water
def hello(name="World"):
return "Hello %s!" % name
if __name__ == '__main__':
water.Water(hello)
Then, from the command line, you can run:
python hello.py # Hello World!
python hello.py --name=David # Hello David!
python hello.py --help # Shows usage information.
Here's an example of calling Water on a class.
import water
class Calculator(object):
"""A simple calculator class."""
def double(self, number):
return 2 * number
if __name__ == '__main__':
water.Water(Calculator)
Then, from the command line, you can run:
python calculator.py double 10 # 20
python calculator.py double --number=15 # 30
To learn how Water behaves on functions, objects, dicts, lists, etc, and to learn about Water's other features, see the Using a Water CLI page.
For additional examples, see The Python Water Guide.
Why is it called Water?
When you call Water, it flows off (executes) your command.
Where can I learn more?
Please see The Python Water Guide.
Reference
| Setup | Command | Notes |
|---|---|---|
| install | pip install python-water |
Installs water from pypi |
| Creating a CLI | Command | Notes |
|---|---|---|
| import | import water |
|
| Call | water.Water() |
Turns the current module into a CLI. |
| Call | water.Water(component) |
Turns component into a CLI. |
| Type Casting | Command | Notes |
|---|---|---|
| Auto-cast | def foo(x: int) |
Water casts CLI args to annotated types. |
| Custom types | water.register_type_constructor(T, fn) |
Define how CLI args become type T. |
| Example | python examples/type_casting.py |
Full working example. |
| Using a CLI | Command | Notes |
|---|---|---|
| Help | command --help or command -- --help |
|
| REPL | command -- --interactive |
Enters interactive mode. |
| Separator | command -- --separator=X |
Sets the separator to X. Default is -. |
| Completion | command -- --completion [shell] |
Generates a completion script for the CLI. |
| Trace | command -- --trace |
Gets a Water trace for the command. |
| Verbose | command -- --verbose |
Note that these flags are separated from the Water command by an isolated --.
License
Licensed under the Apache 2.0 License.
Disclaimer
This is not an official Google product.
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 python_water-1.0.0.tar.gz.
File metadata
- Download URL: python_water-1.0.0.tar.gz
- Upload date:
- Size: 109.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
37e57be63ab5c6a2924f64ccb7d556e13040d59af55479af6eeec295e3011cbf
|
|
| MD5 |
2d7138aaf6fae016f87467e75245873a
|
|
| BLAKE2b-256 |
01733928201b6a6b3e6b6ccbca76faf520159085a239cc2c692d0cb74a00a937
|
Provenance
The following attestation bundles were made for python_water-1.0.0.tar.gz:
Publisher:
publish.yml on penut-slop/python-water
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
python_water-1.0.0.tar.gz -
Subject digest:
37e57be63ab5c6a2924f64ccb7d556e13040d59af55479af6eeec295e3011cbf - Sigstore transparency entry: 1263623882
- Sigstore integration time:
-
Permalink:
penut-slop/python-water@b1feb7c2af27a473a7551af9651fe6fcd5005f62 -
Branch / Tag:
refs/tags/v1.0.0 - Owner: https://github.com/penut-slop
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@b1feb7c2af27a473a7551af9651fe6fcd5005f62 -
Trigger Event:
release
-
Statement type:
File details
Details for the file python_water-1.0.0-py3-none-any.whl.
File metadata
- Download URL: python_water-1.0.0-py3-none-any.whl
- Upload date:
- Size: 83.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6d567c4e8669d7da8dc0d71f73df147e4f0ee1f038e48c4aba0cd33fbf3d4c9e
|
|
| MD5 |
2188060aca127f1640d3ab6c8489c417
|
|
| BLAKE2b-256 |
a69f9240c17a40d7b8a804859b32e48f101d21c5bc64fe97582aed5fb5648392
|
Provenance
The following attestation bundles were made for python_water-1.0.0-py3-none-any.whl:
Publisher:
publish.yml on penut-slop/python-water
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
python_water-1.0.0-py3-none-any.whl -
Subject digest:
6d567c4e8669d7da8dc0d71f73df147e4f0ee1f038e48c4aba0cd33fbf3d4c9e - Sigstore transparency entry: 1263623949
- Sigstore integration time:
-
Permalink:
penut-slop/python-water@b1feb7c2af27a473a7551af9651fe6fcd5005f62 -
Branch / Tag:
refs/tags/v1.0.0 - Owner: https://github.com/penut-slop
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@b1feb7c2af27a473a7551af9651fe6fcd5005f62 -
Trigger Event:
release
-
Statement type: