Skip to main content

Export MkDocs Material markdown files to clean DOCX documents using pandoc

Project description

mkdocx

Export MkDocs Material markdown files to clean DOCX documents using pandoc.

Converts MkDocs markdown files into standard DOCX documents ready to be pasted into a branded template. Heading levels are shifted down by one (Markdown H2 becomes Word Heading 1, etc.) since H1 is the page title handled by MkDocs.

Installation

uv tool install mkdocx

With support for post-processing wide tables

uv tool install mkdocx[postprocess]

Installation From Source

uv tool install .

With support for post-processing wide tables

uv tool install .[postprocess]

Installation for Development

uv pip install -e ".[dev]"

Requirements

  • Python 3.10+
  • pandoc must be installed and available on PATH (or specify with --pandoc)
  • Optional: python-docx for post-processing wide tables (install with pip install mkdocx[postprocess])

Usage

# Single file (output defaults to docx-exports/<filename>.docx)
mkdocx docs/guides/getting-started.md

# Single file with explicit output path
mkdocx docs/guides/getting-started.md -o getting-started.docx

# Single file into a specific output folder
mkdocx docs/guides/getting-started.md -of docx-exports/custom

# Export an entire directory (mirrors structure relative to docs/)
mkdocx docs/guides/

# Export a directory, filtering by frontmatter tag
mkdocx docs/ --tag report

# Export with tag into a custom output folder
mkdocx docs/ -t report -of docx-exports/custom

CLI reference

mkdocx <input> [-o OUTPUT | -of [OUTPUT_FOLDER]] [-t TAG] [--pandoc PATH] [--preserve-heading-numbers]
Flag Description
input Path to a markdown file or directory
-o, --output Explicit DOCX output path (single file only, mutually exclusive with -of)
-of, --output-folder Output folder (default: docx-exports/)
-t, --tag Filter by frontmatter tag (directory mode only)
--pandoc Path to pandoc binary (auto-detected if omitted)
--preserve-heading-numbers Keep leading numbers like "1. Introduction" in headings

Output behaviour

Input Flags Output path
File (none) docx-exports/<stem>.docx
File -o path.docx path.docx
File -of folder folder/<stem>.docx
Directory (none) docx-exports/ mirroring structure relative to docs/
Directory -of folder folder/ mirroring structure relative to docs/
Directory -t policy docx-exports/tag/policy/<stem>.docx (flat)
Directory -t policy -of dir dir/tag/policy/<stem>.docx (flat)

Features

  • Macro resolution - {{ extra_var }} placeholders from mkdocs.yml are replaced
  • Relative link rewriting - .md links become full site URLs
  • Admonition conversion - !!! / ??? blocks become styled fenced divs
  • Heading shift - H2 becomes H1, H3 becomes H2, etc.
  • Empty header table fix - promotes first data row when header is blank
  • Abbreviation stripping - removes *[ABBR]: ... definition lines
  • Content-aware table widths - Lua filter balances column proportions
  • Wide table font shrinking - tables with 4+ columns get a smaller font size

Development

# Install dev dependencies
uv pip install -e ".[dev]"

# Run tests
pytest

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

mkdocx-0.1.2.tar.gz (41.8 kB view details)

Uploaded Source

Built Distribution

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

mkdocx-0.1.2-py3-none-any.whl (11.8 kB view details)

Uploaded Python 3

File details

Details for the file mkdocx-0.1.2.tar.gz.

File metadata

  • Download URL: mkdocx-0.1.2.tar.gz
  • Upload date:
  • Size: 41.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mkdocx-0.1.2.tar.gz
Algorithm Hash digest
SHA256 69820ad70cb72c59ee03062c3725c233ca8892f173efc38f0a0c7be9d8b0f7c1
MD5 a9b7be5a61613bef33af12be6acdce22
BLAKE2b-256 bc26459abf2e9c4e66dbe9b013c5fae864f12f83d9b13f87fea80151db90f3a1

See more details on using hashes here.

Provenance

The following attestation bundles were made for mkdocx-0.1.2.tar.gz:

Publisher: publish.yml on Aidenwebb/mkdocx

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

File details

Details for the file mkdocx-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: mkdocx-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 11.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mkdocx-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 72b9ec0e19826cb15810f816ddadaae49969ede10cd9b78ec2d679426bfca992
MD5 5cad78720f6ead19679de0ccc9bd3aec
BLAKE2b-256 ccabcafb3033955875f6b31faf7a4f2da960fe400ed45a92326cdb56fea59881

See more details on using hashes here.

Provenance

The following attestation bundles were made for mkdocx-0.1.2-py3-none-any.whl:

Publisher: publish.yml on Aidenwebb/mkdocx

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