Skip to main content

Wrapper for Python's argparse to also read arguments from a file

Project description

ARGPARSE-FROM-FILE

PyPi AUR

argparse-from-file is a lightweight wrapper for Python's standard argparse module. It allows your program to read default arguments from a configuration file, which are prepended to arguments provided on the command line.

The latest version of this document and code is available at https://github.com/bulletmark/argparse-from-file.

Features

  • Drop-in replacement: Simply change import argparse to import argparse_from_file as argparse. No other code changes are needed for basic functionality.
  • Automatic configuration: By default, it loads arguments from <program_name>-flags.conf in the user's configuration directory (e.g., ~/.config/ on Linux). The exact path is determined using the platformdirs library to respect OS conventions.
  • Custom configuration file: Specify a custom file path with the from_file argument to ArgumentParser().
  • Simple file format: The configuration file is a simple text file with options specified on one or more lines. Blank lines and lines starting with # are ignored.
  • Informative help text: The program's help message is automatically updated to show the path to the configuration file.

Usage

To get started, replace the standard argparse import in your project:

# import argparse
import argparse_from_file as argparse

That's it! Your application will now automatically look for a default configuration file and use the default arguments provided therein.

To specify a custom configuration file, use the from_file keyword argument, which is the only addition to the standard ArgumentParser() API:

# Use a specific file path
parser = argparse.ArgumentParser(from_file='/path/to/my/config', ..)

# Use a file relative to the user's config directory
parser = argparse.ArgumentParser(from_file='my-app.conf', ..)

The from_file argument accepts a string or a pathlib.Path. Relative paths are resolved relative to the user's configuration directory as determined by platformdirs.

Configuration File Format

Arguments in the configuration file are best specified one per line so they can easily be commented out. It is also recommended to use long-form options for clarity.

Example ~/.config/myprog-flags.conf:

--verbose

# Always run with foo set to 123
--foo 123

Customizing the Help Message

argparse-from-file automatically adds an epilog to the help message indicating the configuration file path. If you instead provide a custom epilog (or usage or description), you can embed a #FROM_FILE_PATH# placeholder, and it will be replaced with the actual path used.

Example

Here is a simple example program (myprog.py):

#!/usr/bin/python3
import argparse_from_file as argparse

parser = argparse.ArgumentParser()
parser.add_argument('--foo', type=int, default=42, help='foo help')
opts = parser.parse_args()

print(f"foo is: {opts.foo}")

If ~/.config/myprog-flags.conf contains --foo=123, the output is:

$ python myprog.py
foo is: 123

The help text (epilog) is also automatically added as seen below:

$ python myprog.py -h
usage: myprog.py [-h] [--foo FOO]

options:
  -h, --help  show this help message and exit
  --foo FOO   foo help

Note you can set default starting options in /home/user/.config/myprog-flags.conf.

Installation

Arch Linux users can install python-argparse-from-file from the AUR.

Alternatively, argparse-from-file is available on PyPI and can be installed with pip:

pip install argparse-from-file

License

Copyright (C) 2025 Mark Blakeney. This program is distributed under the terms of the GNU General Public License. This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License at https://opensource.org/license/gpl-3-0 for more details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

argparse_from_file-1.2.tar.gz (5.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

argparse_from_file-1.2-py3-none-any.whl (4.7 kB view details)

Uploaded Python 3

File details

Details for the file argparse_from_file-1.2.tar.gz.

File metadata

  • Download URL: argparse_from_file-1.2.tar.gz
  • Upload date:
  • Size: 5.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.2

File hashes

Hashes for argparse_from_file-1.2.tar.gz
Algorithm Hash digest
SHA256 73566fcfb699435fd60c08d86144d4c77f9b3b3e9ab96591860a803340e1ba49
MD5 d2f560aba20648dd851744804e3d8978
BLAKE2b-256 e7ff3d5dcf5b6b5031607a042eef9e95c7e22791a2eec956222c4aada7619c73

See more details on using hashes here.

File details

Details for the file argparse_from_file-1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for argparse_from_file-1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 e2cc631101a429c5fdc65df04e3cc5d73ade9782e0548225df44c77d981afb18
MD5 8a5ee753809126b006190b1a8cba8bfe
BLAKE2b-256 e7af69280eff2795f49b390ce82106b6d6e1620f3f2ecfe0a9cbc2aa231bdbbf

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page