python-fire

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

Github stars Tracking Chart

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. (docs/benefits.md#simple-cli)
  • Python Fire is a helpful tool for developing and debugging Python code. (docs/benefits.md#debugging)
  • Python Fire helps with exploring existing code or turning other people's code
    into a CLI. (docs/benefits.md#exploring)
  • Python Fire makes transitioning between Bash and Python easier. (docs/benefits.md#bash)
  • 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. (docs/benefits.md#repl)

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.

Main metrics

Overview
Name With Ownergoogle/python-fire
Primary LanguagePython
Program languagePython (Language Count: 1)
Platform
License:Other
所有者活动
Created At2017-02-21 21:35:07
Pushed At2025-09-01 17:41:27
Last Commit At2025-08-16 17:26:04
Release Count13
Last Release Namev0.7.1 (Posted on )
First Release Namev0.1.0 (Posted on 2017-03-29 13:19:49)
用户参与
Stargazers Count27.9k
Watchers Count365
Fork Count1.5k
Commits Count355
Has Issues Enabled
Issues Count333
Issue Open Count126
Pull Requests Count135
Pull Requests Open Count26
Pull Requests Close Count112
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private