The UML Class Diagram Generator is a powerful Python-based tool designed to automatically generate UML class diagrams from Python source code. It parses your Python files, extracts class definitions, methods, and attributes, and creates a structured UML diagram in XML format. This diagram can be easily visualized using tools like draw.io.
This tool is perfect for developers and teams who want to quickly visualize the architecture of their Python projects without manually drawing class diagrams.
- Automatic Class Parsing: Detects and parses class definitions, including methods and attributes.
- Import Resolution: Automatically resolves and includes imported files within the specified package.
- Interactive Command-Line Interface: Guides you through selecting the base directory and main script for UML generation.
- UML Diagram in XML: Outputs the UML class diagram in XML format, ready to be opened with diagram tools like draw.io.
You can install the UML Class Diagram Generator directly from PyPI:
pip install uml-class-diagram-generatorAfter installing, you can generate UML class diagrams using the command-line tool generate-uml.
-
Navigate to your project directory:
cd /path/to/your/project -
Run the UML generator:
generate-uml
-
Follow the prompts:
- Enter the base package directory (default is
src). - Select the main script for which you want to generate the UML diagram.
- Enter the name of the sub-package directory to resolve imports.
- Enter the base package directory (default is
-
Find your UML Diagram:
- The tool will generate an XML file named
<sub_package_directory>_class_diagram.xml. - Open this XML file in draw.io to view the class diagram.
- The tool will generate an XML file named
Let's say you have the following directory structure:
my_project/
│
├── src/
│ ├── main.py
│ └── module/
│ └── my_class.py
└── tests/
└── test_my_class.py
You would run generate-uml, specify src as the base directory, select main.py as the main script, and provide module as the sub-package directory. The tool will then generate a module_class_diagram.xml file containing the UML diagram for the classes in main.py and my_class.py.
Contributions are welcome! If you'd like to contribute to this project, please fork the repository and submit a pull request. For major changes, please open an issue to discuss what you would like to change.
This project is licensed under the MIT License - see the LICENSE file for details.
If you encounter any issues or have questions, feel free to open an issue on the GitHub repository.
- This tool leverages Python's Abstract Syntax Tree (AST) module to parse and analyze Python source code.
- Inspired by the need for efficient project architecture visualization.