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.1: Pangu extension.
  • v0.3.0: Change the entry function to a class, add TOC and footnotes 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.3.tar.gz (24.8 kB view details)

Uploaded Source

Built Distribution

marko-0.3.3-py2.py3-none-any.whl (33.7 kB view details)

Uploaded Python 2 Python 3

File details

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

File metadata

  • Download URL: marko-0.3.3.tar.gz
  • Upload date:
  • Size: 24.8 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.3.tar.gz
Algorithm Hash digest
SHA256 198ac1d63d7c97566f46734c99e9a6dd4059aca4e6f453586702e10b24f005e4
MD5 48518bf6d9441ceaf01e84a04bfd8f85
BLAKE2b-256 d4a16aff0e238414b24034c2e952695c14d72a766a83da258f9c0d99201ada7c

See more details on using hashes here.

Provenance

File details

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

File metadata

  • Download URL: marko-0.3.3-py2.py3-none-any.whl
  • Upload date:
  • Size: 33.7 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.3-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 614facca24b8cb54aea48e3f7e04dcc301dbd790ac245b64e510069ab0e9ff63
MD5 24a25e98fe3d3dc4e190be9c6cdd9c92
BLAKE2b-256 580573a59c44ff6b35eaa9e9b1194c4ba5fdee1c60b0cba32d5bdc6f74ff175b

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page