Skip to main content

Python module import analysis tool

Project description

FindImports

FindImports extracts Python module dependencies by parsing source files. It can report names that are imported but not used, and it can generate module import graphs in ASCII or graphviz or JSON formats.

A distinguishing feature of findimports used to be that it could parse doctest code inside docstrings.

Note that not all cases are handled correctly, especially if you use ‘import foo.bar.baz’, or rely on PEP 420 implicit namespace packages.

If you need to find unused imports in your codebase, I recommend flake8 instead – it’s better maintained and more reliable. For import graphs consider pydeps.

Installation

Use your favorite Python command-line tool installer such as pipx or uv. Or run it without installing with

uvx findimports --help

Module dependency graphs

On larger projects the module graphs tend to be an unreadable mess. You can make them clearer by post-processing the graph with tred to remove graph edges representing direct dependencies to modules that you’re already transitively depending on:

uvx findimports -N -q src -d | tred | xdot -

tred is part of graphviz. xdot is a nice interactive graphviz viewer.

Misc

Home page: https://github.com/mgedmin/findimports

Licence: MIT (https://mit-license.org/)

buildstatus coverage

Changes

3.0.0 (2025-12-08)

  • -t/--tred to compute a transitive reduction of the import graph. Somewhat experimental.

  • Bugfix: names getting imported from a package’s foo/__init__.py` were not being correctly tracked; they instead were treated as imports from an external package ‘foo’, while ‘foo.__init__’ was shown to be with no incoming edges.

Backwards incompatible changes: modules named __init__ are now treated as packages, so instead of foo.__init__ in the output you’ll see just foo.

2.8.0 (2025-12-06)

  • -l/--levels now works even without using -p. This lets you collapse subpackages while still seeing modules inside the top-level package.

2.7.0 (2025-11-14)

  • Add support for Python 3.14.

  • Drop support for Python 3.8 and 3.9.

  • Add --quiet/-q to suppress “could not find some.module” warnings.

  • Add --json/-j to produce JSON output.

  • Support glob patterns in --ignore/-I. Make the default ignore pattern .*.

Backwards incompatible changes: venv is no longer ignored by default. The Python community has settled on .venv as the default directory name for a project-local virtual environment, which is now ignored by the new default ignore pattern.

2.6.0 (2025-06-02)

  • Drop support for Python 3.7.

  • Add --csv/-C output format: pull request 32.

  • Add --search-import/-s command-line option to filter imports by substring: pull request 33.

2.5.2 (2024-11-27)

  • Bugfix: findimports was treating all imports as relative, just like in the good old Python 2 days. Oops.

  • When reporting that it couldn’t find the source for an imported module, findimports will now mention the line number that contained the import statement.

2.5.1 (2024-10-09)

  • Add support for Python 3.13.

2.5.0 (2024-05-30)

2.4.0 (2024-02-01)

  • Add support for Python 3.12.

  • Change license from GPL to MIT. See issue 27.

  • Add --package-externals/-pE to simplify the module graph.

  • Add --rmprefix PREFIX/-R PREFIX to remove a package prefix from displayed names.

  • Add --depth N/-D N to ignore import statements nested too deep in the syntax tree (e.g. in functions or if statements).

2.3.0 (2022-10-27)

  • Rewrote command-line parsing to use argparse. Options that select an action (--imports/--dot/--names/--unused) now conflict instead of all but the last one being ignored. See pull request #20.

  • Add support for Python 3.11.

  • Drop support for Python 3.6.

2.2.0 (2021-12-16)

  • Add support for Python 3.10.

  • Add --ignore-stdlib flag to ignore modules from the Python standard library.

2.1.0 (2021-05-16)

  • Add --ignore flag to ignore files and directories, it can be used multiple times. See pull request #14.

2.0.0 (2021-05-09)

  • Add support for Python 3.9.

  • Drop support for Python 3.5 and 2.7.

  • Fix a bug where the encoding of Python files was not determined in the same way as by Python itself. See issue 15. This requires the use of tokenize.open which is not in Python 2.7.

1.5.2 (2019-10-31)

  • Add support for Python 3.8.

  • Fix a bug where a package/module with a name that is a prefix of another package/module might accidentally be used instead of the other one (e.g. py instead of pylab). See issue 10.

1.5.1 (2019-04-23)

  • Drop support for Python 3.4.

1.5.0 (2019-03-18)

  • Support Python 3.6 and 3.7.

  • Drop support for Python 2.6 and 3.3.

  • Suppress duplicate import warnings if the line in question has a comment.

1.4.1 (2016-09-28)

  • Replace getopt with optparse. This changes the --help message as a side effect (#4).

1.4.0 (2015-06-04)

  • Python 3 support (3.3 and newer).

  • Use ast instead of compiler (#1).

1.3.2 (2015-04-13)

  • Fix “cannot find datetime” on Ubuntu 14.04 LTS (#3).

  • 100% test coverage.

1.3.1 (2014-04-16)

  • Added support for relative imports (e.g. from .. import foo).

1.3.0 (2013-04-10)

  • Moved to Github.

  • Drop Python 2.4 and 2.5 support.

  • Handle unicode docstrings with doctests.

1.2.14 (2012-02-12)

1.2.13 (2011-04-18)

  • Suppress “not a zipfile” warnings about *.egg-info files listed in sys.path.

1.2.12 (2011-04-08)

  • Handle zipfile errors when there are plain files that are not zip files on sys.path.

1.2.11 (2011-03-30)

  • Fix ‘could not find cPickle’ errors on Python 2.6 and newer.

1.2.10 (2010-02-05)

  • Ignore ‘from __future__ import …’.

1.2.9 (2009-07-07)

  • Fixed broken and uninstallable source distribution by adding a MANIFEST.in.

1.2.8 (2009-07-07)

  • Is able to find modules inside zip files (e.g. eggs).

  • Fixed deprecation warning on Python 2.6.

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

findimports-3.0.0.tar.gz (30.9 kB view details)

Uploaded Source

Built Distribution

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

findimports-3.0.0-py3-none-any.whl (16.5 kB view details)

Uploaded Python 3

File details

Details for the file findimports-3.0.0.tar.gz.

File metadata

  • Download URL: findimports-3.0.0.tar.gz
  • Upload date:
  • Size: 30.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for findimports-3.0.0.tar.gz
Algorithm Hash digest
SHA256 91c8b9962bccfc856562033089fb63ea41186419f0a3500e97449e85f301f615
MD5 2d78643d01eca6d3341c934e9773fdfc
BLAKE2b-256 9d5de4c476ec4b6d6bf212a9e0124c0f9ec6d5c097e10963df1c8829a73de7de

See more details on using hashes here.

File details

Details for the file findimports-3.0.0-py3-none-any.whl.

File metadata

  • Download URL: findimports-3.0.0-py3-none-any.whl
  • Upload date:
  • Size: 16.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for findimports-3.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 29a8276a1f1363d2cec7fe901c43072b392b330bcf9614b160f9fd5348c97ceb
MD5 17921a30bef792a5f52a201e62519fcf
BLAKE2b-256 dab680337c8592183c41afbb802f5fdb516dc0e24aa2c09958ddafe46dd27a38

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