Python Markdown Formatting



  • Almost 4 times faster4 than Python-Markdown in pure Python environment, almost 5 times faster with Cython's help.
  • Rich is a Python library for rich text and beautiful formatting in the terminal.

Markdown is a common markup language frequently used by developers to writePython project documention.

Markdown is a type of markup language often used to document Python projects. Learn more about Markdown on Full Stack Python.

Markdown's origin

Markdown was originallydeveloped by John Gruberin 2004. The markup language's lightweight design helped it gain rapidadoption by software developers and designers. The format's simplicity alsomakes it easier to write parsers to convert the structured syntax intoother formats such as HTML and JSON.

Markdown resources

Markdown does not have an extensive set of strict rules like some othertext formats so you should be able to read up on the basics with thesearticles then write a few practice documents to be comfortable with it.The following resources are really helpful when you are getting startedor need a quick reference on a less commonly-used feature such as tablesor block quotes.

  • Say yes to Markdown, no to MS Wordprovides a really awesome overview of why Markdown is a more usable fileformat than Microsoft Word and similar proprietary file types. The articlealso has a good list of useful Markdown-related tools such as aMarkdown-to-PDF converter(a NodeJS package but easy enough to use with a basic developmentenvironment).

  • Markdown syntaxis the defacto standard and wonderful reading for both initial learningand random reference.

  • Markdown cheatsheetis a quick reference that is a shortened version of the above Markdownsyntax page.

  • Markdown parsers in Pythonreviews many of the most common Python Markdown parser implementationsto give insight into the advantages and disadvantages of each one.

  • reStructuredText vs Markdown for documentationbrings up some really good points about the downsides to Markdown'ssimplicity. First, a lot of documentation needs more complex output thatis not possible with vanilla Markdown so you need to drop into plain oldHTML, which defeats the purpose of using a markup language. Second, someof the syntax around inserting blank lines by adding spaces at the endof lines is confusing if someone is using atext editor or development environment thatis not configured to show blank spaces. Worse yet, if your editor is set toremove blank spaces at the end of lines, which is fairly common amongdevelopers, then you can mistakenly break the formatting intended bythe original author. Overall this is a good piece to read for a balancedview of Markdown and the reasons it provides are one reason why I useboth Markdown and reStructuredText depending on the project.

  • The Python Package Index (PyPI)supports Markdown as of 2018although there are still some tweaks being made to the flavors that can beused such as GitHub-flavored Markdown.

  • PowerShell and Markdownshows how to work with Markdown in PowerShellincluding customizing colors and listing some quirks you may need to getaround.

  • reStructuredText vs. Markdown for technical documentationcompares Markdown and reStructuredText specifically for documentingsoftware and explains where each one has advantages.

  • Reach for Markdown, not LaTeXexamines the virtues of using straight Markdown along with tools suchas pandoc to convert from one file format toanother, including how to use Markdown for presentations and not justregular documentation.

  • Markdown page is a JavaScriptfile that makes it easy to render plain old Markdown as a webpage.

What else do you want to learn?

I want to learn how to code a Python web application using a framework.

I've built a Python web app, now how do I deploy it?

There are many markdown parsers in Python. Misaka was my favorite one. However, misaka is deprecated now, and the successor which is called hoedown still has issues to solve. That's why it is a was. But I still love it.

Here is a list of markdown parsers for Python in my knowledge:

Python Markdown Formatting
  • Misaka: A python binding for Sundown. (CPython required)
  • Hoedown: A python binding for Hoedown, successor of Misaka.
  • Discount: A python binding for Discount. (CPython required)
  • cMarkdown: Markdown for Python, accelerated by C. (CPython required)
  • Markdown: A pure markdown parser, the very first implementation.
  • Markdown2: Another pure markdown parser.

And I've just released another pure markdown parser too, which is called mistune.

Misaka

Misaka was my favorite markdown parser. It is a python binding of Sundown, which means that it has all the features that Sundown provides.

It is super fast! Actually, it is the top one in my benchmarks. Since it is a binding of a C library, no wonder that it is this fast. If speed is what you want, you should try misaka, and as well as other bindings of a C library.

But misaka is more than speed. It is the custom renderer feature that catches my heart. I am so fond of it, that's why I implement the custom renderer feature in my own markdown parser mistune.

A quick and very useful sample is code highlighting.

However, it is a binding of a C libary. It requires CPython, if you prefer PyPy, you have no access to it. Some App Engines have a limitation on compiling C libraries too, you can't use misaka in this case. And even if you are using CPython, it is still difficult to install it on a Windows OS.

Visual Studio's support for C is not optimal and most VS compilers are missing stdint.h, which is needed to compile Misaka.

If you are on a Windows, may god helps you. I don't care it a shit.

Footnote feature is missing in Misaka. Maybe many of you don't need such a thing, in this case, misaka has nothing bad. It is stable, efficient, and has many GFM features.

The only trouble is Sundown is deprecated.1

Python Markdown Formatting Examples

Hoedown

Python markdown formatting example

Because the Sundown library is deprecated, here comes hoedown2, which is the fork of the original Sundown. It has a Python binding also called as hoedown.

Since Hoedown is the successor of Sundown, and python-hoedown is the successor of Misaka, all features that misaka has, python-hoedown has them too. But python-hoedown is more than that.

  1. It is PyPy compatible.
  2. It has footnote feature.

It looks promissing, and even misaka's author recommends it. I've tried it, but failed with one issue, a magic error that I can't do anything:

This isssue is not fixed yet. Once it does, hoedown would be a good choice for non-AE users.

Updated at Jun 23, 2014: you can use Hoep as the Python Binding.

cMarkdown & Discount

cMarkdown is much like Misaka, except that it is based on upskirt3 rather than sundown. The history is very interesting, sundown is a fork of upskirt, hoedown is a fork of sundown. And now, sundown is deprecated, upskirt is missing. The new markdown parser that vmg promised is still not available.

cMarkdown has all the disadvantages of Misaka, and it is a little slower than Misaka. This means you really should use misaka instead of cMarkdown.

Markdown

Discount is a joke for me, I can't even install it successfully! There is not much to say. But I do know that Discount is slower than Sundown.

Markdown & Markdown2

Python-Markdown is the very first markdown parser in pure Python. It is good, except the documentation. However, I miss the renderer feature in misaka, which is not in Python-Markdown.

Python-Markdown is not that slow as I expected, since Python-Markdown2 calls itself as:

A fast and complete implementation of Markdown in Python.

But it is not true. Python-Markdown2 is much slower than Python-Markdown. I have no idea why it says itself fast. All features that 2 has, the older one has too.

The benchmark shows that Python-Markdown2 is almost twice slower than Python-Markdown. No wonder it is 2.

Mistune

Mistune is a new (just released) markdown parser. It is the fastest one in all pure Python implementations. Almost 4 times faster4 than Python-Markdown in pure Python environment, almost 5 times faster with Cython's help.

I didn't expect it to be so fast when I wrote it. I know it would be a fast one, but I didn't know that it would be 4 times faster and even 5 times faster.

I have never thought of creating a Markdown parser my own. But it has been months since I reported the issue to Hoedown. The issue is still there, not solved a bit. Because it is a C binding, I am not able to do any help, the only thing I can do is waiting.

I don't use Python-Markdown or Python-Markdown2, because they have no renderer feature, and they are slow.

I have introduced renderer feature to marked, which is finally merged. And now I am trying to add the footnote feature. It occured to me that I can port marked to Python, since I know marked well, and I know it is the fastest in all pure JavaScript implementations. It would be fast in Python too, and it really does.

If you are looking for a fast, full featured5 and pure Python implementation, Mistune is a good choice. It also has renderer feature just like Misaka. You can always influnce the rendering results with custom renderers.

Additional Notes

I did a benchmark on my MacBook Air, view the results. You can run the benchmark script yourself: bench.py

Mistune can be compiled with Cython if you have Cython installed already.

Python Markdown Formatting Example

The magic happens in the setup.py script. I'd like to introduce this part another time.

Python Format Markdown Table

mistune is used by many great projects such as IPython, Rodeo and crossbar.

*This post and all posts in markdown format on this site are rendered with mistune.*