Skip to content
Python Fire is a library for automatically generating command line interfaces (CLIs) from absolutely any Python object.
Python
Branch: master
Clone or download

Latest commit

uburuntu and Copybara-Service Support for Python 3.8
- Enables Travis for 3.8
- Fixes namedtuple test for 3.8

COPYBARA_INTEGRATE_REVIEW=#263 from uburuntu:master efaf65f
PiperOrigin-RevId: 316134191
Change-Id: I5e3ef20b488fa917b81525d5936a8e147b0458e1
Latest commit 457b156 Jun 12, 2020

Files

Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
docs Documentation updates for '--help' and 'python -m fire' Mar 13, 2020
examples Fix warnings in the diff example (#135) Aug 28, 2018
fire Support for Python 3.8 Jun 12, 2020
.gitignore Add type-checking to Python Fire via pytype. Mar 4, 2019
.travis.yml Support for Python 3.8 Jun 12, 2020
CONTRIBUTING.md Initial commit for Python Fire. Feb 15, 2017
LICENSE Initial commit for Python Fire. Feb 15, 2017
MANIFEST.in Adds MANIFEST.in to Python Fire (properly including LICENSE file in s… Jul 24, 2017
README.md Documentation updates for '--help' and 'python -m fire' Mar 13, 2020
mkdocs.yml - Rename doc to docs in preparation for adding mkdocs support. Jul 17, 2017
pylintrc Adds useless-object-inheritance and no-else-return to pylintrc disable Jul 23, 2018
requirements.txt Cleans up formatting and adds requirements.txt file. Mar 7, 2017
setup.cfg Add type-checking to Python Fire via pytype. Mar 4, 2019
setup.py Support for Python 3.8 Jun 12, 2020

README.md

Python Fire PyPI

Python Fire is a library for automatically generating command line interfaces (CLIs) from absolutely any Python object.

  • Python Fire is a simple way to create a CLI in Python. [1]
  • Python Fire is a helpful tool for developing and debugging Python code. [2]
  • Python Fire helps with exploring existing code or turning other people's code into a CLI. [3]
  • Python Fire makes transitioning between Bash and Python easier. [4]
  • Python Fire 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 Fire with pip, run: pip install fire

To install Python Fire with conda, run: conda install fire -c conda-forge

To install Python Fire from source, first clone the repository and then run: python setup.py install

Basic Usage

You can call Fire on any Python object:
functions, classes, modules, objects, dictionaries, lists, tuples, etc. They all work!

Here's an example of calling Fire on a function.

import fire

def hello(name="World"):
  return "Hello %s!" % name

if __name__ == '__main__':
  fire.Fire(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 Fire on a class.

import fire

class Calculator(object):
  """A simple calculator class."""

  def double(self, number):
    return 2 * number

if __name__ == '__main__':
  fire.Fire(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 Fire behaves on functions, objects, dicts, lists, etc, and to learn about Fire's other features, see the Using a Fire CLI page.

For additional examples, see The Python Fire Guide.

Why is it called Fire?

When you call Fire, it fires off (executes) your command.

Where can I learn more?

Please see The Python Fire Guide.

Reference

Setup Command Notes
install pip install fire
Creating a CLI Command Notes
import import fire
Call fire.Fire() Turns the current module into a Fire CLI.
Call fire.Fire(component) Turns component into a Fire CLI.
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. The default separator is -.
Completion command -- --completion [shell] Generates a completion script for the CLI.
Trace command -- --trace Gets a Fire trace for the command.
Verbose command -- --verbose

Note that these flags are separated from the Fire command by an isolated --.

License

Licensed under the Apache 2.0 License.

Disclaimer

This is not an official Google product.

You can’t perform that action at this time.