Skip to main content

A markdown parser with high extensibility.

Project description

Marko

A markdown parser with high extensibility.

Build 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:

import marko
marko.markdown('A long 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

Note that the signature of marko.markdown():

def markdown(text, parser=Parser, renderer=HTMLRenderer):
    ...

You can supply your own parser or renderer to it.

  • A parser is what parses the document into separated elements.
  • A renderer is what renders given element into desired output, which can be HTML in the most common situation.

License

Marko is released under MIT License

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.1.0.tar.gz (24.0 kB view details)

Uploaded Source

Built Distribution

marko-0.1.0-py2.py3-none-any.whl (26.5 kB view details)

Uploaded Python 2 Python 3

File details

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

File metadata

  • Download URL: marko-0.1.0.tar.gz
  • Upload date:
  • Size: 24.0 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.1.0.tar.gz
Algorithm Hash digest
SHA256 e89a9985d0aee4c4cd0e68580856abe292a68077aad043d31bb8b97f2f335d8c
MD5 90c4e63545e7e8ddfbbe039d2692b248
BLAKE2b-256 cc19d2faa9edcfe82d0a2f87245ce30cfd5c214fffcde6f9214edb56dbd6e284

See more details on using hashes here.

File details

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

File metadata

  • Download URL: marko-0.1.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 26.5 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.1.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 9cfa3298895fa778c517e0f7b6537fb1b22d1670e57461aebf89408838dc7136
MD5 e23a430193be49bc61d9d78e536d3a72
BLAKE2b-256 071c3c83d10d74ec2c300f1a65bac2b5c54cefa2e9df1ef790a1a9445baec207

See more details on using hashes here.

Supported by

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