rst2html5 generates (X)HTML5 documents from standalone reStructuredText sources. It is a complete rewrite of the docutils' rst2html and uses new HTML5 constructs as <section> and <aside>.


$ rst2html5 [options] <source>


--stylesheet=<URL or path>
 Specify comma separated list of stylesheet URLs.
--script=<URL or path>
 Specify comma separated list of script URLs.
--no-indent Don't indent output
 Specify the maximum width (in characters) for options in option lists. Longer options will span an entire row of the table used to render the option list. Default is 0 characters which means "no limit".


Consider the following rst snippet:


Some text and a target to `Title 2`_. **strong emphasis**:

* item 1
* item 2

Title 2

.. parsed-literal::

    Inline markup is supported, e.g. *emphasis*, **strong**, ``literal
    _`hyperlink targets`, and `references <>`_

The html5 produced is clean and tidy:

<!DOCTYPE html>
<html lang="en">
    <meta charset="utf-8" />
    <a id="title"></a>
        <p>Some text and a target to <a href="#title-2">Title 2</a>. <strong>strong emphasis</strong>:</p>
            <li>item 1</li>
            <li>item 2</li>
    <a id="title-2"></a>
        <h1>Title 2</h1>
        <pre>Inline markup is supported, e.g. <em>emphasis</em>, <strong>strong</strong>, <code>literal
<a id="hyperlink-targets">hyperlink targets</a>, and <a href="">references</a></pre>

No stylesheets or classes are spread over the html5 by default. However:

  1. Stylesheets and javascritps URLs or paths can be included through stylesheet and script options:

    $ rst2html5 example.rst --stylesheet "css/default.css, css/special/css" \
    <!DOCTYPE html>
    <html lang="en">
        <meta charset="utf-8" />
        <link href="css/default.css" rel="stylesheet" />
        <link href="css/special/css" rel="stylesheet" />
        <script src=""></script>
  2. Classes can be explicitly associated to rst elements (see ref):

    .. class:: special
    This is a "special" paragraph.
    .. class:: exceptional remarkable
    An Exceptional Section
    This is an ordinary paragraph.

    which results in:

    <p class="special">This is a "special" paragraph.</p>
    <a id="an-exceptional-section"></a>
    <section class="exceptional remarkable">
        <h1>An Exceptional Section</h1>
        <p>This is an ordinary paragraph.</p>


$ pip install rst2html5


MIT License