Skip to main content

Requirement (dependency) management for python projects

Project description

dependence

test distribute

This project provides a Command Line Interface and library for inspecting and updating python project dependency versions in setup.cfg, pyproject.toml, and requirements.txt files.

Installation

You can install dependence with pip:

pip3 install dependence

Usage

Command Line Interface

$ dependence -h
Usage:
  dependence <command> [options]

Commands:
  update                      Update requirement versions in the specified
                              files to align with currently installed versions
                              of each distribution
  freeze                      Print dependencies inferred from an installed
                              distribution or project, in a similar format
                              to the output of `pip freeze`.

dependence update

This command will update version specifiers for all package requirements in your setup.cfg, pyproject.toml, tox.ini, or requirements.txt files to match currently installed versions of each distribution (matching the existing granularity, and only for inclusive specifiers—so where the comparator is "~=", "==", ">=", or "<=", but not where the comparator is ">", "<", or "!=").

$ dependence update -h
usage: dependence update [-h] [-i IGNORE] [-aen ALL_EXTRA_NAME]
                           path [path ...]

Update requirement versions in the specified files to align with currently
installed versions of each distribution.

positional arguments:
  path                  One or more local paths to a setup.cfg,
                        setup.cfg, and/or requirements.txt file

optional arguments:
  -h, --help            show this help message and exit
  -i IGNORE, --ignore IGNORE
                        A comma-separated list of distributions to ignore
                        (leave any requirements pertaining to the package
                        as-is)
  -aen ALL_EXTRA_NAME, --all-extra-name ALL_EXTRA_NAME
                        If provided, an extra which consolidates the
                        requirements for all other extras will be
                        added/updated to setup.cfg or setup.cfg
                        (this argument is ignored for requirements.txt
                        files)

Example:

dependence update -aen all setup.cfg pyproject.toml tox.ini

dependence freeze

$ dependence freeze -h
usage: dependence freeze [-h] [-e EXCLUDE] [-er EXCLUDE_RECURSIVE] [-nv NO_VERSION]
                         [-do] [--reverse] [-d DEPTH]
                         requirement [requirement ...]

This command prints dependencies inferred from an installed distribution or project, in
a similar format to the output of `pip freeze`, except that all generated requirements
are specified in the format "distribution-name==0.0.0" (including for editable
installations). Using this command instead of `pip freeze` to generate requirement
files ensures that you don't bloat your requirements files with superfluous
distributions.

positional arguments:
  requirement           One or more requirement specifiers (for example: "requirement-
                        name", "requirement-name[extra-a,extra-b]", ".[extra-a,
                        extra-b]" or "../other-editable-package-directory[extra-a,
                        extra-b]) and/or paths to a setup.py, setup.cfg,
                        pyproject.toml, tox.ini or requirements.txt file

optional arguments:
  -h, --help            show this help message and exit
  -e EXCLUDE, --exclude EXCLUDE
                        A distribution (or comma-separated list of distributions) to
                        exclude from the output
  -er EXCLUDE_RECURSIVE, --exclude-recursive EXCLUDE_RECURSIVE
                        A distribution (or comma-separated list of distributions) to
                        exclude from the output. Unlike -e / --exclude, this argument
                        also precludes recursive requirement discovery for the
                        specified packages, thereby excluding all of the excluded
                        package's requirements which are not required by another (non-
                        excluded) distribution.
  -nv NO_VERSION, --no-version NO_VERSION
                        Don't include versions (only output distribution names) for
                        packages matching this/these glob pattern(s) (note: the value
                        must be single-quoted if it contains wildcards)
  -do, --dependency-order
                        Sort requirements so that dependents precede dependencies
  --reverse             Print requirements in reverse order
  -d DEPTH, --depth DEPTH
                        Depth of recursive requirement discovery

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

dependence-0.3.1.tar.gz (20.7 kB view details)

Uploaded Source

Built Distribution

dependence-0.3.1-py3-none-any.whl (20.2 kB view details)

Uploaded Python 3

File details

Details for the file dependence-0.3.1.tar.gz.

File metadata

  • Download URL: dependence-0.3.1.tar.gz
  • Upload date:
  • Size: 20.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.4

File hashes

Hashes for dependence-0.3.1.tar.gz
Algorithm Hash digest
SHA256 3356950375d01aa154bbb74e5bb21ae96315250220d13b6338bd43a0eee90383
MD5 5b64f194741e19ae91536d2dae980208
BLAKE2b-256 6cb22081adedebaae23cd2e8545f9e5d65174f2842fbd9e806dfbf55c0130a8c

See more details on using hashes here.

File details

Details for the file dependence-0.3.1-py3-none-any.whl.

File metadata

  • Download URL: dependence-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 20.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.4

File hashes

Hashes for dependence-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 eca5dfc6400a4349db4e18c98e588f3884146f3d7c87db1e4fc0a26b9260d3c9
MD5 c4a1c96e281ab37c8b91f083aed7cd15
BLAKE2b-256 6082c4b2eba953cee1fa26633b7e54d146d88650bb41ba871f5000414191bbb0

See more details on using hashes here.

Supported by

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