Python Fire
last modified February 22, 2025
In this article, we show how to use the Fire module to create command-line interfaces (CLIs) in Python.
Fire is a Python library that automatically generates command-line interfaces (CLIs) from any Python object, including functions, classes, and modules.
With Fire, you can turn any Python component into a CLI with minimal effort. This makes it an excellent tool for automating the creation of CLIs for your scripts, libraries, and applications.
Simple CLI
The first example demonstrates how to create a simple CLI using Fire.
import fire def greet(name="guest"): return f"Hello, {name}!" if __name__ == '__main__': fire.Fire(greet)
In this program, we define a simple function greet
that takes an
optional argument name
. Fire automatically generates a CLI for this
function.
import fire
We import the Fire module.
def greet(name="guest"): return f"Hello, {name}!"
This is a simple function that greets the user. The name
parameter
has a default value of "World".
if __name__ == '__main__': fire.Fire(greet)
We use fire.Fire
to turn the greet
function into a CLI.
When the script is run, Fire automatically generates a CLI based on the function.
$ python main.py --name=Alice Hello, Alice! $ python main.py Hello, guest!
We run the script with and without the --name
argument.
CLI with a class
In the next example, we create a CLI using a class.
import fire class Calculator: def add(self, a, b): return a + b def subtract(self, a, b): return a - b def multiply(self, a, b): return a * b def divide(self, a, b): return a / b if __name__ == '__main__': fire.Fire(Calculator)
In this program, we define a Calculator
class with four methods:
add
, subtract
, multiply
, and
divide
. Fire generates a CLI for the class, allowing us to call
these methods from the command line.
class Calculator: def add(self, a, b): return a + b def subtract(self, a, b): return a - b def multiply(self, a, b): return a * b def divide(self, a, b): return a / b
This is the Calculator
class with four arithmetic methods.
if __name__ == '__main__': fire.Fire(Calculator)
We use fire.Fire
to turn the Calculator
class into a
CLI. Fire automatically generates commands for each method in the class.
We run the script with different commands and arguments to perform arithmetic operations.
Creating nested commands
Fire also supports nested commands, allowing you to create more complex CLIs.
import fire class Math: def add(self, a, b): return a + b def subtract(self, a, b): return a - b class String: def concat(self, a, b): return a + b def repeat(self, a, times): return a * times class CLI: def __init__(self): self.math = Math() self.string = String() if __name__ == '__main__': fire.Fire(CLI)
In this program, we define two classes, Math
and String
,
each with their own methods. We then create a CLI
class that
instantiates these classes as attributes. Fire generates a CLI with nested
commands for each class.
class Math: def add(self, a, b): return a + b def subtract(self, a, b): return a - b class String: def concat(self, a, b): return a + b def repeat(self, a, times): return a * times
These are the Math
and String
classes with their
respective methods.
class CLI: def __init__(self): self.math = Math() self.string = String()
The CLI
class instantiates the Math
and
String
classes as attributes.
if __name__ == '__main__': fire.Fire(CLI)
We use fire.Fire
to turn the CLI
class into a CLI.
Fire generates nested commands for the math
and string
attributes.
$ python main.py math add 3 5 8 $ python main.py string repeat falcon 3 falconfalconfalcon
We run the script with nested commands to perform operations from the
Math
and String
classes.
CLI from dictionary
It is possible to derive commands from a dictionary.
import fire def add(a, b): return a + b def multiply(a, b): return a * b commands = { 'add': add, 'multiply': multiply, } if __name__ == '__main__': fire.Fire(commands)
We define two functions. The functions are mapped to commands via a dictionary.
Variable number of arguments
When we define a function with a parameter preceded by an asterisk (*), such as
*elements
, it means that the function can accept any number of
positional arguments, which are then packed into a tuple.
import fire def sort_elements(*elements): """Sort the given elements.""" sorted_elements = sorted(elements) return sorted_elements def uppercase_elements(*elements): """Convert the given elements to uppercase.""" uppercased_elements = [element.upper() for element in elements] return uppercased_elements commands = { 'sort': sort_elements, 'upper': uppercase_elements, } if __name__ == '__main__': fire.Fire(commands)
The program has two functions to sort and uppercase its elements.
$ py main.py sort war atom sky blue say pine atom blue pine say sky war $ python main.py upper war atom sky blue say pine WAR ATOM SKY BLUE SAY PINE
Source
In this article, we have worked with the Python Fire module to create command-line interfaces (CLIs) in Python.
Author
List all Python tutorials.