Skip to main content

No project description provided

Project description

MermaidGenerator

Automatically generate Mermaid class diagrams from Python source code.

PyPI version Python License

MermaidGenerator parses your Python files using the AST and produces a Markdown file with embedded Mermaid class diagrams — no runtime execution required. See an example output.

Made by Fabian Gnatzig in 2026.


Features

  • Class attributes with type annotations
  • Method signatures including argument types and return types
  • Inheritance relationships with links between diagrams
  • @staticmethod and @classmethod — marked with $
  • @abstractmethod — marked with *
  • @property — rendered as a typed attribute, backing field suppressed
  • Abstract base classes (ABC) — rendered with <<abstract>> stereotype
  • @dataclass and other decorators — rendered as Mermaid stereotypes
  • Public (+) and private (-) visibility based on naming convention
  • Union types (X | Y), generics (list[str]), and qualified types (typing.Optional)
  • Works on single files or entire project trees

Installation

pip install mermaidgenerator

Usage

python -m mermaidgenerator --src-folder <path> [--doc-path <output>]
Argument Required Description
--src-folder yes Root directory of your Python project to scan
--doc-path no Output path for the .md file (default: <src-folder>/../class_diagrams.md)
--exclude no Glob pattern of files to skip, relative to --src-folder (can be repeated)

Examples

# Basic usage
python -m mermaidgenerator --src-folder src --doc-path docs/class_diagrams.md

# Exclude test files and a specific module
python -m mermaidgenerator --src-folder src --exclude "**/test_*.py" --exclude "migrations/*.py"

Example output

Given a class like this:

from abc import ABC, abstractmethod

class Shape(ABC):
    """Abstract base class for shapes."""

    def __init__(self, color: str) -> None:
        self.color: str = color

    @abstractmethod
    def area(self) -> float: ...

    @staticmethod
    def describe(color: str) -> str: ...

MermaidGenerator produces:

# Shape
Abstract base class for shapes.
```mermaid
classDiagram
    class Shape {
<<abstract>>
+ str color
- __init__(color: str) None
+ area() float *
+ describe(color: str) str $
}
```

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

mermaidgenerator-1.2.0a2.tar.gz (18.0 kB view details)

Uploaded Source

Built Distribution

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

mermaidgenerator-1.2.0a2-py3-none-any.whl (18.8 kB view details)

Uploaded Python 3

File details

Details for the file mermaidgenerator-1.2.0a2.tar.gz.

File metadata

  • Download URL: mermaidgenerator-1.2.0a2.tar.gz
  • Upload date:
  • Size: 18.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mermaidgenerator-1.2.0a2.tar.gz
Algorithm Hash digest
SHA256 f4c49cb0ff7b048d9cb0a50cdb2a9333c9dfbe788f253e5af235a279b3654f67
MD5 60c231dbadcd102b088425e73af687ef
BLAKE2b-256 2028c24d3f61ea7a5bbb062f1468cea211c87ace2a03f992d092d9e6b68a2027

See more details on using hashes here.

Provenance

The following attestation bundles were made for mermaidgenerator-1.2.0a2.tar.gz:

Publisher: publish.yaml on FabianGnatzig/MermaidGenerator

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mermaidgenerator-1.2.0a2-py3-none-any.whl.

File metadata

File hashes

Hashes for mermaidgenerator-1.2.0a2-py3-none-any.whl
Algorithm Hash digest
SHA256 9e84dcbbacde32f7cc50efb6ae8bb8186d6bef63a75b8f8fdc5676ab9770738e
MD5 c7b97bce86dd48cf6ba52e15bf3454ff
BLAKE2b-256 ca8695f169e28e2020eec013dfc4dd03a34ae4e777146f3216998392dde6892a

See more details on using hashes here.

Provenance

The following attestation bundles were made for mermaidgenerator-1.2.0a2-py3-none-any.whl:

Publisher: publish.yaml on FabianGnatzig/MermaidGenerator

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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