Skip to main content

Convert Obsidian-flavored Markdown to PDF and DOCX via a 5-stage pipeline

Project description

obsidian-export

Convert Obsidian-flavored Markdown to PDF and DOCX. Handles wikilinks, embeds, callouts, Mermaid diagrams, and frontmatter — producing clean, professional documents via a 5-stage pipeline (vault ops → preprocess → mermaid → SVG → pandoc).

Documentation | PyPI | Changelog

Installation

conda-forge (recommended)

Installs obsidian-export with pandoc included automatically. You must separately install tectonic >= 0.15 and librsvg (not yet available on all platforms via conda-forge). Run obsidian-export doctor to check.

conda install -c conda-forge obsidian-export

Or with pixi:

pixi global install obsidian-export

Note: The conda-forge package is pending review. Until it's accepted, install from source using pixi:

git clone https://github.com/neuralsignal/obsidian-export.git
cd obsidian-export
pixi install
pixi run obsidian-export --help

pip

pip install obsidian-export

With pip, you must separately install pandoc >= 3.5, tectonic >= 0.15, and librsvg. Run obsidian-export doctor to check.

Mermaid Support (optional)

For Mermaid diagram rendering, install Node.js >= 20 and mermaid-cli:

npm install -g @mermaid-js/mermaid-cli

Quick Start

# Convert with default settings
obsidian-export convert --input my_note.md --format pdf --output my_note.pdf

# Convert to DOCX
obsidian-export convert --input my_note.md --format docx --output my_note.docx

# Use a custom profile
obsidian-export convert --input my_note.md --format pdf --output my_note.pdf --profile my_brand

Profile Management

Profiles are YAML config files stored in ~/.obsidian-export/profiles/.

# Initialize directory structure and default profile
obsidian-export init

# Create a new profile (starts from defaults)
obsidian-export profile create my_brand

# Create from existing YAML
obsidian-export profile create my_brand --from existing_config.yaml

# List profiles
obsidian-export profile list

# Show profile contents
obsidian-export profile show my_brand

# Delete a profile
obsidian-export profile delete my_brand --yes

Custom Styles

Styles are LaTeX header templates. Place custom styles in ~/.obsidian-export/styles/<name>/header.tex.

Style resolution order:

  1. style_dir field in config (explicit path)
  2. Built-in styles (default)
  3. User styles in ~/.obsidian-export/styles/<name>/
  4. Treat style name as a filesystem path

Configuration

A config YAML can override any subset of defaults. Only include fields you want to change:

# Minimal override — everything else uses defaults
style:
  fontsize: "12pt"
  mainfont: "Georgia"
  line_spacing: 1.5

Full Config Reference

mermaid:
  mmdc_bin: "mmdc"          # Path to Mermaid CLI binary
  scale: 3                  # PNG render scale

obsidian:
  wikilink_strategy: "text"           # How to handle [[wikilinks]]
  url_strategy: "footnote_long"       # bare URL handling: keep|footnote_long|footnote_all|strip
  url_length_threshold: 60            # URL length for footnote_long strategy

pandoc:
  from_format: "gfm-tex_math_dollars+footnotes" # Pandoc input format

style:
  name: "default"                     # Style name (resolves to header.tex template)
  geometry: "a4paper,margin=25mm"     # Page geometry
  fontsize: "10pt"                    # Base font size
  mainfont: ""                        # Main font (XeLaTeX)
  sansfont: ""                        # Sans font
  monofont: ""                        # Mono font
  linkcolor: "NavyBlue"              # Internal link color
  urlcolor: "NavyBlue"               # URL color
  line_spacing: 1.0                  # Line spacing multiplier
  table_fontsize: "small"            # Font size in tables
  image_max_height_ratio: 0.40       # Max image height as fraction of page
  url_footnote_threshold: 60         # URL length threshold for footnoting
  header_left: ""                    # Left header (supports {doc_title}, {logo_path})
  header_right: ""                   # Right header
  footer_left: ""                    # Left footer
  footer_center: "\\thepage"         # Center footer
  footer_right: ""                   # Right footer
  logo: ""                           # Logo filename (relative to config dir)
  style_dir: ""                      # Explicit style directory path
  unicode_chars:                     # Unicode → LaTeX substitutions
    "⚠": "\\ensuremath{\\triangle}"
    "✅": "\\ensuremath{\\checkmark}"
    "❌": "\\ensuremath{\\times}"
    # ... see default.yaml for full list
  callout_colors:
    note: [219, 234, 254]
    tip: [220, 252, 231]
    warning: [254, 243, 199]
    danger: [254, 226, 226]
  brand_colors:                      # Custom named colors (empty = none)
    petrol: [20, 75, 95]
    turkis: [0, 152, 160]
  heading_styles:                    # Custom heading formats (empty = default)
    - level: "section"               # LaTeX level: section, subsection, subsubsection
      size: "Large"                  # LaTeX size: huge, LARGE, Large, large, normalsize
      bold: true
      sans: true                     # Use sans-serif font
      color: "petrol"               # Reference to brand_colors name or LaTeX color
      uppercase: false
    - level: "subsection"
      size: "large"
      bold: true
      sans: true
      color: "turkis"
      uppercase: true                # Render heading text in UPPERCASE
  title_style: null                  # Custom title block (null = default)
    # size: "huge"
    # bold: true
    # sans: true
    # color: "petrol"
    # date_visible: true
    # vskip_after: "2em"

Python API

from pathlib import Path
from obsidian_export import run
from obsidian_export.config import default_config, load_config

# Using defaults
config = default_config()
run(Path("my_note.md"), Path("output.pdf"), "pdf", config)

# Using a config file
config = load_config(Path("my_config.yaml"))
run(Path("my_note.md"), Path("output.pdf"), "pdf", config)

What It Does

Obsidian Syntax Result
![[embed]] Resolved inline (content inlined)
[[Entity|Display]] Replaced with Display
[[Entity]] Replaced with Entity
> [!note] callouts Colored boxes (PDF) or blockquotes (DOCX)
```mermaid Rendered to PNG
## Relations section Removed
YAML frontmatter Title extracted, tags → keywords, rest removed
$25/user Safe literal dollar sign

License

MIT

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

obsidian_export-0.5.4.tar.gz (27.7 kB view details)

Uploaded Source

Built Distribution

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

obsidian_export-0.5.4-py3-none-any.whl (39.9 kB view details)

Uploaded Python 3

File details

Details for the file obsidian_export-0.5.4.tar.gz.

File metadata

  • Download URL: obsidian_export-0.5.4.tar.gz
  • Upload date:
  • Size: 27.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for obsidian_export-0.5.4.tar.gz
Algorithm Hash digest
SHA256 7ed1c99547df6dea04643d0ac4c3f36a6b10d7bbd841e2a6249dc32cdcda9616
MD5 53dd43aafc98c91de2197a3b720c19d7
BLAKE2b-256 ad14a198dc217650478cf4fd0f4d0ea93e3605f7f3c27a45ca22a699149a27b8

See more details on using hashes here.

Provenance

The following attestation bundles were made for obsidian_export-0.5.4.tar.gz:

Publisher: publish.yml on neuralsignal/obsidian-export

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

File details

Details for the file obsidian_export-0.5.4-py3-none-any.whl.

File metadata

  • Download URL: obsidian_export-0.5.4-py3-none-any.whl
  • Upload date:
  • Size: 39.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for obsidian_export-0.5.4-py3-none-any.whl
Algorithm Hash digest
SHA256 f642b4e282c16b583a931671c72cce60d14fdaea9226b081dc21e7d05a20c7e9
MD5 44bf6fc2e94f9aa10312fb03caa87571
BLAKE2b-256 38dc3fb0212c1354ce0e1c5e517c4a51d72f4f936db29e4941acd788ebb63501

See more details on using hashes here.

Provenance

The following attestation bundles were made for obsidian_export-0.5.4-py3-none-any.whl:

Publisher: publish.yml on neuralsignal/obsidian-export

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