Command-line tool to visualize Python project dependencies.
Project description
DepCycle
DepCycle is a command-line tool to visualize Python project dependencies. It helps developers understand complex codebases by automatically generating visual maps of how modules are connected, making it easy to spot architectural problems like circular dependencies and untangle coupled code.
Features
- Automatic Dependency Discovery: Scans Python projects and builds a complete dependency graph
- Cycle Detection: Identifies circular dependencies that can lead to architectural issues
- Flexible Visualization: Multiple output formats including PNG, SVG, and HTML
- Smart Filtering: Exclude specific patterns, third-party libraries, or standard library modules
- AST-Based Parsing: Uses Python's Abstract Syntax Tree for accurate import detection
Links
- Repository: https://github.com/Matricess/depcycle.git
- Tests: https://github.com/Matricess/depcycle/tree/main/tests
- Design commentary: https://github.com/Matricess/depcycle/blob/main/DESIGN.md
- Sample dependency graph:
examples/(local)
Prerequisites
- Python 3.8 or higher
- Graphviz (for PNG/SVG output)
Installing Graphviz
macOS:
brew install graphviz
Ubuntu/Debian:
sudo apt-get install graphviz
Windows: Download and install from Graphviz website
Installation
Install via pip (recommended)
pip install depcycle
or
# install directly from GitHub
pip install git+https://github.com/Matricess/depcycle.git
Install from a clone (editable dev setup)
git clone https://github.com/Matricess/depcycle.git
cd depcycle
pip install -e .[dev]
If you prefer requirements files, pip install -r requirements.txt will install runtime deps plus pytest for the test suite.
Usage
Basic Usage
Analyze a Python project and generate a dependency graph (PNG by default):
depcycle /path/to/your/project
The output is written to dependencies.png in the current working directory.
Note: By default DepCycle skips common noise directories such as
venv/,.venv/,.git/,__pycache__/,node_modules/, build artifacts, and Python cache folders. Use-eflags if you need extra exclusions, or disable the defaults via the API (Project.get_python_files(include_defaults=False)).
Using as a Module
python -m depcycle /path/to/your/project
Advanced Options
Generate a different output format or explicit location:
depcycle /path/to/project --format svg --output diagrams/dependencies.svg
Exclude specific directories or files (glob syntax):
depcycle /path/to/project -e venv -e ".*/tests/*" -e "*.test.py"
Focus only on local code:
depcycle /path/to/project --no-third-party --no-stdlib
Full help:
depcycle --help
Tests
Tests live under tests/ and run without touching the sample projects in examples/.
pip install -e .[dev]
pytest -q
See tests/README.md for a quick summary.
Project Structure
depcycle/
├── src/
│ └── depcycle/
│ ├── __init__.py
│ ├── __main__.py
│ ├── cli.py # Command-line interface
│ ├── config.py # Configuration management
│ ├── graph/
│ │ ├── __init__.py
│ │ ├── dependency_graph.py # Core graph logic
│ │ └── module_node.py # Module representation
│ ├── parsing/
│ │ ├── __init__.py
│ │ ├── ast_parser.py # AST-based import parsing
│ │ └── project.py # File discovery
│ └── rendering/
│ ├── __init__.py
│ ├── interface.py # Visualization interface
│ └── visualizers.py # Output implementations
├── requirements.txt
├── README.md
└── LICENSE
Architecture
DepCycle follows a clean, modular architecture:
- CLI Layer (
cli.py): Handles user input and orchestrates the workflow - Configuration (
config.py): Manages all settings and options - Graph Layer (
graph/): Core data structures for the dependency graph - Parsing Layer (
parsing/): Discovers files and extracts imports using AST - Rendering Layer (
rendering/): Generates visualizations in various formats
Key Classes
DepCycleCLI: Main entry point that handles command-line argumentsDependencyGraph: Central data structure holding all module relationshipsModuleNode: Represents a single Python module/fileProject: Discovers and manages Python files in a projectASTParser: Extracts imports using Python's AST moduleGraphvizVisualizer: Renders graphs as PNG/SVG imagesHtmlVisualizer: Generates interactive HTML visualizations
How It Works
- Discovery: Recursively scans the project directory for all
.pyfiles - Parsing: Uses Python's AST to extract import statements from each file
- Resolution: Maps import strings to actual modules in the project
- Classification: Categorizes modules as LOCAL, THIRD_PARTY, or STDLIB
- Analysis: Detects circular dependencies using depth-first search
- Visualization: Renders the graph using Graphviz or HTML
Example Output
When you run DepCycle, you'll see output like:
Analyzing project: /path/to/my-project
Building dependency graph...
Found 42 modules
✓ No circular dependencies detected
Generating PNG visualization...
✓ Visualization saved to: dependencies.png
If circular dependencies are found:
⚠️ Warning: Found 2 circular dependency cycles!
Cycle 1: app.models.user → app.services.auth → app.models.user
Cycle 2: app.core.database → app.core.config → app.core.database
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
License
This project is licensed under the MIT License - see the LICENSE file for details.
Acknowledgments
Built as part of a Software Design and Testing course project (IT643).
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file depcycle-0.2.0.tar.gz.
File metadata
- Download URL: depcycle-0.2.0.tar.gz
- Upload date:
- Size: 23.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6454b808d204209481fe783968a27177fe0bd14c49ca6ae1409283fff568d5f7
|
|
| MD5 |
19115e7145954b224480dd63b20c2a12
|
|
| BLAKE2b-256 |
f619095964b520abe98722e296bd5d895cf85301cf2532d6051212f73b464cc8
|
File details
Details for the file depcycle-0.2.0-py3-none-any.whl.
File metadata
- Download URL: depcycle-0.2.0-py3-none-any.whl
- Upload date:
- Size: 23.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6f7e8c58ace585d56dc8f1b6228ac909c93c3a0c9d2e311ad738fa769fe08e09
|
|
| MD5 |
55e3eb547019b5db2a8f6ba326b26bed
|
|
| BLAKE2b-256 |
21a3120db644ea63c2e0cacc3c5b8d5d96bd60a917c1cf03c7421ac253d05d6b
|