CLI Arguments with Environment VariablesΒΆ
You can also configure a CLI argument to read a value from an environment variable if it is not provided in the command line as a CLI argument.
Tip
You can learn more about environment variables in the Environment Variables page.
To do that, use the envvar
parameter for typer.Argument()
:
import typer
from typing_extensions import Annotated
def main(name: Annotated[str, typer.Argument(envvar="AWESOME_NAME")] = "World"):
print(f"Hello Mr. {name}")
if __name__ == "__main__":
typer.run(main)
π€ Other versions and variants
Tip
Prefer to use the Annotated
version if possible.
import typer
def main(name: str = typer.Argument("World", envvar="AWESOME_NAME")):
print(f"Hello Mr. {name}")
if __name__ == "__main__":
typer.run(main)
In this case, the CLI argument name
will have a default value of "World"
, but will also read any value passed to the environment variable AWESOME_NAME
if no value is provided in the command line:
Multiple environment variablesΒΆ
You are not restricted to a single environment variable, you can declare a list of environment variables that could be used to get a value if it was not passed in the command line:
import typer
from typing_extensions import Annotated
def main(
name: Annotated[str, typer.Argument(envvar=["AWESOME_NAME", "GOD_NAME"])] = "World",
):
print(f"Hello Mr. {name}")
if __name__ == "__main__":
typer.run(main)
π€ Other versions and variants
Tip
Prefer to use the Annotated
version if possible.
import typer
def main(name: str = typer.Argument("World", envvar=["AWESOME_NAME", "GOD_NAME"])):
print(f"Hello Mr. {name}")
if __name__ == "__main__":
typer.run(main)
Check it:
Hide an env var from the help textΒΆ
By default, environment variables used will be shown in the help text, but you can disable them with show_envvar=False
:
import typer
from typing_extensions import Annotated
def main(
name: Annotated[
str, typer.Argument(envvar="AWESOME_NAME", show_envvar=False)
] = "World",
):
print(f"Hello Mr. {name}")
if __name__ == "__main__":
typer.run(main)
π€ Other versions and variants
Tip
Prefer to use the Annotated
version if possible.
import typer
def main(name: str = typer.Argument("World", envvar="AWESOME_NAME", show_envvar=False)):
print(f"Hello Mr. {name}")
if __name__ == "__main__":
typer.run(main)
Check it:
Technical Details
In Click applications the env vars are hidden by default. π
In Typer these env vars are shown by default. π