Skip to main content

A markdown parser with high extensibility.

Project description

Marko

A markdown parser with high extensibility.

Build Status PyPI Documentation Status

Marko is a markdown parser written in pure Python that complies CommonMark's spec v0.28. It is designed to be highly extensible, see Extend Marko for details.

Marko requires Python 3.4 or higher, Python 2.7 support is still in plan but I guess it is not needed.

Why Marko

Among all implementations of Python's markdown parser, it is a common issue that user can't easily extend it to add his own features. Furthermore, Python-Markdown and mistune don't comply CommonMark's spec. It is a good reason for me to develop a new markdown parser and use it.

Respecting that Marko complies CommonMark's spec at the same time, which is a super complicated spec, Marko's performance will be affected. A benchmark result shows that Marko is 3 times slower than Python-Markdown, but a bit faster than Commonmark-py, much slower than mistune. If performance is a bigger concern to you than spec compliance, you's better choose another parser.

Use Marko

The installation is very simple:

$ pip install marko

And to use it:

from marko import Markdown
markdown = Markdown()
print(markdown(text))

Marko also provides a simple CLI, for example, to render a document and output to a html file:

$ cat my_article.md | marko > my_article.html

Extend Marko

Please refer to Document

License

Marko is released under MIT License

Change Log

  • v0.3.0: Footnote, TOC, pangu extensions
  • v0.2.0: Github flavored markdown and docs.
  • v0.1.0: Commonmark spec tests.

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

marko-0.3.0.tar.gz (24.3 kB view details)

Uploaded Source

Built Distribution

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

marko-0.3.0-py2.py3-none-any.whl (33.0 kB view details)

Uploaded Python 2Python 3

File details

Details for the file marko-0.3.0.tar.gz.

File metadata

  • Download URL: marko-0.3.0.tar.gz
  • Upload date:
  • Size: 24.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.19.1 setuptools/40.0.0 requests-toolbelt/0.8.0 tqdm/4.24.0 CPython/3.7.0

File hashes

Hashes for marko-0.3.0.tar.gz
Algorithm Hash digest
SHA256 2825131b040418a46045292f73b21ab6571bec7f20a12e954655ad1f0814edbd
MD5 95de6acc59a33b24c1be561f3bf0e881
BLAKE2b-256 7b36eaae5310e97969410c63e7c916d8714eab3c1933b02c1a24e2fac4a970b1

See more details on using hashes here.

File details

Details for the file marko-0.3.0-py2.py3-none-any.whl.

File metadata

  • Download URL: marko-0.3.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 33.0 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.19.1 setuptools/40.0.0 requests-toolbelt/0.8.0 tqdm/4.24.0 CPython/3.7.0

File hashes

Hashes for marko-0.3.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 6e9189026ba7753fb3e12d366d99f8e12774e2635b2ce255b473efbeebf62cbd
MD5 c49a971118efd7435ac8cc7e34d59abf
BLAKE2b-256 fac119caf62a94759634b55cdfc9eca9a822d73dad683f8d7002334d437a91ab

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