Skip to main content

Python-Markdown extension for rendering pydantic BaseModel as table

Project description

Mdantic

This is an extension to Python-Markdown. It adds a new syntax so that you can reference a pydantic BaseModel and translate its fields to a markdown table. (Get the name?) I originally make this to generate http api parameter tables with mkdocs, but you can use it for other stuffs if suitable.

The code itself is a direct modification to markdown-include since they do similar things.

Notice: This project is still WIP and need more examples to adapt to most of the possible BaseModel models.

Installation

Just use pip:

pip install markdown-mdantic

Usage

Config options

init_code will execute any python code in the environment when its __init__ is called. In this way you can do something like adding system path, django setup etc, before run.

Note: Please note that the init_code thing is a huge security issue if you run that with untrusted input. Use it with caution!

columns is a comma-separated list of table columns to use in each table. The default is to use all columns ["key", "type", "required", "description", "default"].

mkdocs

example:

markdown_extensions:
    mdantic:
        init_code: |
            import os
            import django
            os.environ.setdefault("DJANGO_SETTINGS_MODULE", "conf.default")
            django.setup()
        columns: [key, type, required, default]

Some time ago the extension name used here should be markdown_mdantic, but after some point it seems there will only be one file after installation in python's site-packages directory (mdantic.py) so now we should use the name mdantic.

reference the model

Each reference must be in one line, starts with $pydantic: (notice the single space after the colon), following the model import path which looks like a.b.c.D where D is the model class itself (which is subclass of BaseModel).

**params**:

$pydantic: src.test.TestGetSchema

customize output

The resulting table is rendered using tabulate, in github style. The columns config option can be used to restrict the columns to show. Styling cannot be changed at the moment. PR is welcomed.

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

markdown-mdantic-2.1.1.tar.gz (6.8 kB view hashes)

Uploaded Source

Built Distribution

markdown_mdantic-2.1.1-py3-none-any.whl (6.7 kB view hashes)

Uploaded Python 3

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