markdown-it-py3.0.0
markdown-it-py3.0.0
Published
Python port of markdown-it. Markdown parsing, done right!
pip install markdown-it-py
Package Downloads
Authors
Project URLs
Requires Python
>=3.8
Dependencies
- mdurl
~=0.1
- psutil
; extra == "benchmarking"
- pytest
; extra == "benchmarking"
- pytest-benchmark
; extra == "benchmarking"
- pre-commit
~=3.0 ; extra == "code_style"
- commonmark
~=0.9 ; extra == "compare"
- markdown
~=3.4 ; extra == "compare"
- mistletoe
~=1.0 ; extra == "compare"
- mistune
~=2.0 ; extra == "compare"
- panflute
~=2.3 ; extra == "compare"
- linkify-it-py
>=1,<3 ; extra == "linkify"
- mdit-py-plugins
; extra == "plugins"
- gprof2dot
; extra == "profiling"
- mdit-py-plugins
; extra == "rtd"
- myst-parser
; extra == "rtd"
- pyyaml
; extra == "rtd"
- sphinx
; extra == "rtd"
- sphinx-copybutton
; extra == "rtd"
- sphinx-design
; extra == "rtd"
- sphinx_book_theme
; extra == "rtd"
- jupyter_sphinx
; extra == "rtd"
- coverage
; extra == "testing"
- pytest
; extra == "testing"
- pytest-cov
; extra == "testing"
- pytest-regressions
; extra == "testing"
markdown-it-py
Markdown parser done right.
- Follows the CommonMark spec for baseline parsing
- Configurable syntax: you can add new rules and even replace existing ones.
- Pluggable: Adds syntax extensions to extend the parser (see the plugin list).
- High speed (see our benchmarking tests)
- Safe by default
- Member of Google's Assured Open Source Software
This is a Python port of markdown-it, and some of its associated plugins. For more details see: https://markdown-it-py.readthedocs.io.
For details on markdown-it itself, see:
Installation
conda install -c conda-forge markdown-it-py
or
pip install markdown-it-py[plugins]
or with extras
conda install -c conda-forge markdown-it-py linkify-it-py mdit-py-plugins
pip install markdown-it-py[linkify,plugins]
Usage
Python API Usage
Render markdown to HTML with markdown-it-py and a custom configuration with and without plugins and features:
from markdown_it import MarkdownIt
from mdit_py_plugins.front_matter import front_matter_plugin
from mdit_py_plugins.footnote import footnote_plugin
md = (
MarkdownIt('commonmark' ,{'breaks':True,'html':True})
.use(front_matter_plugin)
.use(footnote_plugin)
.enable('table')
)
text = ("""
---
a: 1
---
a | b
- | -
1 | 2
A footnote [^1]
[^1]: some details
""")
tokens = md.parse(text)
html_text = md.render(text)
## To export the html to a file, uncomment the lines below:
# from pathlib import Path
# Path("output.html").write_text(html_text)
Command-line Usage
Render markdown to HTML with markdown-it-py from the command-line:
usage: markdown-it [-h] [-v] [filenames [filenames ...]]
Parse one or more markdown files, convert each to HTML, and print to stdout
positional arguments:
filenames specify an optional list of files to convert
optional arguments:
-h, --help show this help message and exit
-v, --version show program's version number and exit
Interactive:
$ markdown-it
markdown-it-py [version 0.0.0] (interactive)
Type Ctrl-D to complete input, or Ctrl-C to exit.
>>> # Example
... > markdown *input*
...
<h1>Example</h1>
<blockquote>
<p>markdown <em>input</em></p>
</blockquote>
Batch:
$ markdown-it README.md README.footer.md > index.html
References / Thanks
Big thanks to the authors of markdown-it:
- Alex Kocharin github/rlidwka
- Vitaly Puzrin github/puzrin
Also John MacFarlane for his work on the CommonMark spec and reference implementations.