Skip to main content

Print PDFs from Markdown Files using Weasyprint

Project description

md2weasypdf

Print PDFs from Markdown Files using Weasyprint

Installation

pip install md2weasypdf

Usage

python -m md2weasypdf <input_folder_or_file> <output_path>

Watch Mode

The watch mode is intended for creation of layouts. The given layouts directory and input directory will be watched for changes.

For VSCode the extension vscode-pdf can be recommended, as it refreshes the displayed PDF automatically.

python -m md2weasypdf <input_folder_or_file> <output_path> --watch

Input

Input files are expected in markdown format with several markdown extensions. The markdown documents can utilize Jinja2 for templating inside the document (e. g. reusing texts).

Bundling

The bundling feature allows to bundle multiple documents into one PDF. This is useful when you want to create one PDF file from multiple source files. The bundling feature is enabled by adding the --bundle flag to the command. The specified input folder will be searched recursively for *.md files, files starting with an underscore will be ignored.

When using the bundle option, a layout has to be specified using --layout and a title for the whole document using --title.

Options

YAML Frontmatter can be used to customize the document layout or add other options which will be passed to the template. The following example shows how a document with frontmatter section could look like:

---
title: My Document Title
layout: doc1
---
Lorem ipsum...

Markdown Extensions

Table of Contents

Insert a table of contents using [TOC]. The table of contents will be generated automatically based on the headlines (lines starting with one or multiple #) in the document.

Table of Abbreviations

Insert a table of abbreviations using [TOA]. The table of abbreviations will be generated automatically based on defined abbreviations (using *[Abbreviation]: Explanation) in the document.

Footnotes

Footnotes let you reference relevant information without disrupting the flow of what you're trying to say:

Here's a simple footnote,[^1] and here's a longer one.[^bignote]

[^1]: This is the first footnote.

[^bignote]: Here's one with multiple paragraphs and code.

    Indent paragraphs to include them in the footnote.

    `{ my code }`

    Add as many paragraphs as you like.

It is possible to reference to the same footnote by using the same footnote label.

Subscript

Use tildes ~ around text to create a subscript formatting.

Checkboxes

Use [ ] to create a checkbox. Use [x] to mark a checkbox as checked.

Input Fields

Use [>input_id] to create a text input. To create a textarea, add |textarea after the input id. To create a date field, add |YYYY-MM-DD after the input id.

To add a placeholder, append the placeholder text within parens to the end of the input id: [>input_id] (placeholder text).

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

md2weasypdf-0.0.7.tar.gz (20.4 kB view details)

Uploaded Source

Built Distribution

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

md2weasypdf-0.0.7-py3-none-any.whl (21.4 kB view details)

Uploaded Python 3

File details

Details for the file md2weasypdf-0.0.7.tar.gz.

File metadata

  • Download URL: md2weasypdf-0.0.7.tar.gz
  • Upload date:
  • Size: 20.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.0.0 CPython/3.12.3

File hashes

Hashes for md2weasypdf-0.0.7.tar.gz
Algorithm Hash digest
SHA256 bc165b16cfb6a03845c76741b75652e73c9c50f95f34803ff6e7ce8f6cc3db14
MD5 7378b249aefde57425e6e53a18a1a5f9
BLAKE2b-256 0f5fd91b68988c1b4a9f27f62a842750dcd5d348a879969eb35ccdc07a74dc18

See more details on using hashes here.

File details

Details for the file md2weasypdf-0.0.7-py3-none-any.whl.

File metadata

  • Download URL: md2weasypdf-0.0.7-py3-none-any.whl
  • Upload date:
  • Size: 21.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.0.0 CPython/3.12.3

File hashes

Hashes for md2weasypdf-0.0.7-py3-none-any.whl
Algorithm Hash digest
SHA256 30bedd53f79e2f55a41f6ff1b2d11dae9b5756faea533fb2f1f398eb6b4135d6
MD5 46f6ead9c5d1a06594429977237b42f9
BLAKE2b-256 429bb25e60cbf1a0a2ba8f4caf707f2ae795a03685be494186c04f25df10a503

See more details on using hashes here.

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