Markdown parser, done right. 100% CommonMark support, extensions, syntax plugins & high speed. Now in Python!

Overview

markdown-it-py

Github-CI Coverage Status PyPI Conda Code style: black PyPI - Downloads

Markdown parser done right.

This is a Python port of markdown-it, and some of its associated plugins. For more details see: https://markdown-it-py.readthedocs.io.

For details on markdown-it itself, see:

Installation

conda install -c conda-forge markdown-it-py

or

pip install markdown-it-py

Usage

Python API Usage

Render markdown to HTML with markdown-it-py and a custom configuration with and without plugins and features:

from markdown_it import MarkdownIt
from markdown_it.extensions.front_matter import front_matter_plugin
from markdown_it.extensions.footnote import footnote_plugin

md = (
    MarkdownIt()
    .use(front_matter_plugin)
    .use(footnote_plugin)
    .disable('image')
    .enable('table')
)
text = ("""
---
a: 1
---

a | b
- | -
1 | 2

A footnote [^1]

[^1]: some details
""")
tokens = md.parse(text)
html_text = md.render(text)

Command-line Usage

Render markdown to HTML with markdown-it-py from the command-line:

usage: markdown-it [-h] [-v] [filenames [filenames ...]]

Parse one or more markdown files, convert each to HTML, and print to stdout

positional arguments:
  filenames      specify an optional list of files to convert

optional arguments:
  -h, --help     show this help message and exit
  -v, --version  show program's version number and exit

Interactive:

  $ markdown-it
  markdown-it-py [version 0.0.0] (interactive)
  Type Ctrl-D to complete input, or Ctrl-C to exit.
  >>> # Example
  ... > markdown *input*
  ...
  <h1>Example</h1>
  <blockquote>
  <p>markdown <em>input</em></p>
  </blockquote>

Batch:

  $ markdown-it README.md README.footer.md > index.html

References / Thanks

Big thanks to the authors of markdown-it:

Also John MacFarlane for his work on the CommonMark spec and reference implementations.

Comments
  • Space in link destination generates IndexError

    Space in link destination generates IndexError

    Describe the bug

    A space character right after a link destination scheme causes an IndexError.

    [Contact](http:// mail.com)
    [Contact](mailto: [email protected])
    

    Reproduce the bug

    from markdown_it import MarkdownIt
    MarkdownIt().parse("[Contact](mailto: [email protected])")
    

    Error

    Traceback (most recent call last):
      File "<stdin>", line 1, in <module>
      File "/Library/Caches/pypoetry/virtualenvs/webapp-gmQ5g8dx-py3.9/lib/python3.9/site-packages/markdown_it/main.py", line 260, in parse
        self.core.process(state)
      File "/Library/Caches/pypoetry/virtualenvs/webapp-gmQ5g8dx-py3.9/lib/python3.9/site-packages/markdown_it/parser_core.py", line 33, in process
        rule(state)
      File "/Library/Caches/pypoetry/virtualenvs/webapp-gmQ5g8dx-py3.9/lib/python3.9/site-packages/markdown_it/rules_core/inline.py", line 10, in inline
        state.md.inline.parse(token.content, state.md, state.env, token.children)
      File "/Library/Caches/pypoetry/virtualenvs/webapp-gmQ5g8dx-py3.9/lib/python3.9/site-packages/markdown_it/parser_inline.py", line 120, in parse
        self.tokenize(state)
      File "/Library/Caches/pypoetry/virtualenvs/webapp-gmQ5g8dx-py3.9/lib/python3.9/site-packages/markdown_it/parser_inline.py", line 102, in tokenize
        ok = rule(state, False)
      File "/Library/Caches/pypoetry/virtualenvs/webapp-gmQ5g8dx-py3.9/lib/python3.9/site-packages/markdown_it/rules_inline/link.py", line 54, in link
        href = state.md.normalizeLink(res.str)
      File "/Library/Caches/pypoetry/virtualenvs/webapp-gmQ5g8dx-py3.9/lib/python3.9/site-packages/markdown_it/main.py", line 331, in normalizeLink
        return normalize_url.normalizeLink(url)
      File "/Library/Caches/pypoetry/virtualenvs/webapp-gmQ5g8dx-py3.9/lib/python3.9/site-packages/markdown_it/common/normalize_url.py", line 21, in normalizeLink
        parsed = mdurl.parse(url, slashes_denote_host=True)
      File "/Library/Caches/pypoetry/virtualenvs/webapp-gmQ5g8dx-py3.9/lib/python3.9/site-packages/mdurl/_parse.py", line 300, in url_parse
        u.parse(url, slashes_denote_host)
      File "/Library/Caches/pypoetry/virtualenvs/webapp-gmQ5g8dx-py3.9/lib/python3.9/site-packages/mdurl/_parse.py", line 204, in parse
        if rest[host_end - 1] == ":":
    IndexError: string index out of range
    

    List your environment

    Python 3.9 markdown-it-py 2.0.1

    bug 
    opened by mib112 15
  • [BUG] More than 1 Block Quote in Text causes IndexError when converting to ipynb

    [BUG] More than 1 Block Quote in Text causes IndexError when converting to ipynb

    Describe the bug

    If there are more than one block quotes in a myst.md file then jupytext (via markdown-it-py) causes

     File "anaconda3/envs/qe-lectures/lib/python3.8/site-packages/markdown_it/rules_block/state_block.py", line 134, in skipEmptyLines
        if (self.bMarks[from_pos] + self.tShift[from_pos]) < self.eMarks[from_pos]:
    IndexError: list index out of range
    

    To Reproduce

    A minimal Example

    ---
    jupytext:
      text_representation:
        extension: .md
        format_name: myst
    kernelspec:
      display_name: Python 3
      language: python
      name: python3
    ---
    
    # Simple Example
    
    > A Block Quote
    
    some text
    
    > Another Block Quote
    
    
    

    and then run jupytext f<ile.md> --to ipynb

    Expected behavior

    Notebook output with a single cell containing markdown and two block-quotes

    Environment

    Jupyter Book: 0.8.3 MyST-NB: 0.10.1 Sphinx Book Theme: 0.0.38 MyST-Parser: 0.12.10 Jupyter-Cache: 0.4.1 NbClient: 0.5.0

    bug 
    opened by mmcky 15
  • ๐Ÿ‘Œ IMPROVE: Parsing performance

    ๐Ÿ‘Œ IMPROVE: Parsing performance

    Hi!

    I was looking at performance and noticed that the charCodeAt function was called a lot with some redundancy.

    We very often compare ord() codes, and I think it's justified to store them in an attribute for StateCore, StateBlock and StateInline. Eg:

    class StateCore(StateBase):
        def __init__(self, src: str, md, env, tokens=None):
            self.src = src
            self.ords = [ord(c) for c in src]
            ...
    

    Then we just replace each variant of: charCodeAt(state.src, pos)

    by

    state.ords[pos]

    Furthermore, StateCore and StateBlock can share a significant part of their ord codes. So we can add an optional parameter to the StateBlock constructor to copy the StateCore ord codes:

    class StateBlock(StateBase):
        def __init__(self, src: str, md, env, tokens: List[Token], ords: List[int] = None):
            self.src = src
    
            if ords is not None:
                self.ords = ords
            else:
                self.ords = [ord(c) for c in src]
    

    Here are some benchmark numbers (100 iterations with benchmark.py):

    markdown-it-py (0.4.9): 18.66 s => Original markdown-it-py (0.4.9): 17.93 s => store ord codes as attributes to remove charCodeAt where possible markdown-it-py (0.4.9): 16.43 s => share StateCore ord codes with StateBlock

    This is a ~10% performance boost.

    However, these changes do not strictly copy the behavior of charCodeAt since it bypasses its try/except clause.

    def charCodeAt(src: str, pos: int):
        try:
            return ord(src[pos])
        except IndexError:
            return None
    

    Tests are OK but I wonder if this can have an impact on illformed markdown ? I could create a specific structure to alleviate this issue (a defaultlist that returns None when there is an IndexError, as is done in charCodeAt), but there would be a small downside in code readability, so I'd like to have your input on this.

    Let me know what you think!

    opened by sildar 15
  • running pytest

    running pytest

    + /usr/bin/python3 -Bm pytest -ra
    =========================================================================== test session starts ============================================================================
    platform linux -- Python 3.8.9, pytest-6.2.4, py-1.10.0, pluggy-0.13.1
    rootdir: /home/tkloczko/rpmbuild/BUILD/markdown-it-py-1.1.0
    plugins: forked-1.3.0, shutil-1.7.0, virtualenv-1.7.0, expect-1.1.0, cov-2.11.1, httpbin-1.0.0, xdist-2.2.1, flake8-1.0.7, timeout-1.4.2, betamax-0.8.1, pyfakefs-4.4.0, freezegun-0.4.2, cases-3.4.6, case-1.5.3, isort-1.3.0, aspectlib-1.5.2, mock-3.6.0, asyncio-0.15.1, toolbox-0.5, xprocess-0.17.1, flaky-3.7.0, requests-mock-1.9.2, aiohttp-0.3.0, checkdocs-2.7.0, hypothesis-6.12.1
    collected 863 items
    INTERNALERROR> Traceback (most recent call last):
    INTERNALERROR>   File "/usr/lib/python3.8/site-packages/_pytest/main.py", line 269, in wrap_session
    INTERNALERROR>     session.exitstatus = doit(config, session) or 0
    INTERNALERROR>   File "/usr/lib/python3.8/site-packages/_pytest/main.py", line 322, in _main
    INTERNALERROR>     config.hook.pytest_collection(session=session)
    INTERNALERROR>   File "/usr/lib/python3.8/site-packages/pluggy/hooks.py", line 286, in __call__
    INTERNALERROR>     return self._hookexec(self, self.get_hookimpls(), kwargs)
    INTERNALERROR>   File "/usr/lib/python3.8/site-packages/pluggy/manager.py", line 93, in _hookexec
    INTERNALERROR>     return self._inner_hookexec(hook, methods, kwargs)
    INTERNALERROR>   File "/usr/lib/python3.8/site-packages/pluggy/manager.py", line 84, in <lambda>
    INTERNALERROR>     self._inner_hookexec = lambda hook, methods, kwargs: hook.multicall(
    INTERNALERROR>   File "/usr/lib/python3.8/site-packages/pluggy/callers.py", line 208, in _multicall
    INTERNALERROR>     return outcome.get_result()
    INTERNALERROR>   File "/usr/lib/python3.8/site-packages/pluggy/callers.py", line 80, in get_result
    INTERNALERROR>     raise ex[1].with_traceback(ex[2])
    INTERNALERROR>   File "/usr/lib/python3.8/site-packages/pluggy/callers.py", line 187, in _multicall
    INTERNALERROR>     res = hook_impl.function(*args)
    INTERNALERROR>   File "/usr/lib/python3.8/site-packages/_pytest/main.py", line 333, in pytest_collection
    INTERNALERROR>     session.perform_collect()
    INTERNALERROR>   File "/usr/lib/python3.8/site-packages/_pytest/main.py", line 636, in perform_collect
    INTERNALERROR>     self.config.pluginmanager.check_pending()
    INTERNALERROR>   File "/usr/lib/python3.8/site-packages/pluggy/manager.py", line 274, in check_pending
    INTERNALERROR>     raise PluginValidationError(
    INTERNALERROR> pluggy.manager.PluginValidationError: unknown hook 'pytest_benchmark_update_machine_info' in plugin <module 'conftest' from '/home/tkloczko/rpmbuild/BUILD/markdown-it-py-1.1.0/benchmarking/conftest.py'>
    
    ========================================================================== no tests ran in 0.29s ===========================================================================
    
    question 
    opened by kloczek 13
  • โœจ NEW: Add simple typographic replacements

    โœจ NEW: Add simple typographic replacements

    Issue

    #5

    Summary

    Implemented replacements (Simple typographic replacements) rule.

    Change

    • Added a test to make sure that even a single capital letter is matched correctly.
    opened by tsutsu3 12
  • ๐Ÿ‘Œ IMPROVE: Ensure len(state.src) == len(state.srcCharCode)

    ๐Ÿ‘Œ IMPROVE: Ensure len(state.src) == len(state.srcCharCode)

    def normalize(state: StateCore) -> None:
    
        # Normalize newlines
        string = NEWLINES_RE.sub("\n", state.src)
    
        # Replace NULL characters
        string = NULL_RE.sub("\uFFFD", string)
    
        state.src = string
    

    When updating state.src, state.srcCharCode should be updated synchronously.

    opened by geebos 11
  • empty lines at end of certain files cause parse to fail

    empty lines at end of certain files cause parse to fail

    Describe the bug

    The presence of three empty lines at the end of a particular file causes the build to break.

    To Reproduce

    Steps to reproduce the behavior:

    1. Clone https://github.com/poldrack/psych-open-science-guide
    2. "jb build guide" should work properly
    3. Add two additional line feeds to the end of guide/4_reproducibleanalysis.md
    4. "jb build guide" should now fail with an error.

    Expected behavior

    When the extra lines are added, the follow Exception occurs:

    Environment

    • Python 3.8.3

    • output of jupyter-book --version: Jupyter Book: 0.7.3 MyST-NB: 0.8.4 Sphinx Book Theme: 0.0.33 MyST-Parser: 0.9.0 Jupyter-Cache: 0.2.2

    • Operating System: Mac OS X

    bug 
    opened by poldrack 10
  • An md file, or notebook cell, ending in a blockquote with a blank line,  causes a crash

    An md file, or notebook cell, ending in a blockquote with a blank line, causes a crash

    Describe the bug

    Consider a notebook that contains the following cell:

    > test
    >
    

    or a markdown file with the above. The key point is that the cell/markdown content must end with a blockquote that has a blank line at the end, still part of the block quote. The python short traceback is (I'll attach the long one):

    Exception occurred:
      File "/Users/fperez/local/conda/lib/python3.9/site-packages/markdown_it/rules_block/blockquote.py", line 158, in blockquote
        if state.srcCharCode[pos] == 0x20:  # /* space */
    IndexError: tuple index out of range
    

    Reproduce the bug

    Running a build with a notebook with the above (or an md file) should suffice.

    List your environment

    > jupyter-book --version
    Jupyter Book      : 0.11.3
    External ToC      : 0.2.3
    MyST-Parser       : 0.13.7
    MyST-NB           : 0.12.3
    Sphinx Book Theme : 0.1.10
    Jupyter-Cache     : 0.4.3
    NbClient          : 0.5.10
    
    bug 
    opened by fperez 9
  • Empty `alt` attribute, and `store_labels` only works for reference links

    Empty `alt` attribute, and `store_labels` only works for reference links

    Describe the bug

    Image tokens always have an empty alt attribute, and the option store_labels doesn't work for inline links (only reference ones).

    To Reproduce

    Steps to reproduce the behavior:

    Python 3.8.3 (default, Jun  7 2020, 18:20:38) 
    Type 'copyright', 'credits' or 'license' for more information
    IPython 7.19.0 -- An enhanced Interactive Python. Type '?' for help.
    
    In [1]: from markdown_it import MarkdownIt                                                                     
    
    In [2]: md = MarkdownIt()                                                                                      
    
    In [3]: src = 'this is a ![picture](test.png "so nice") of a thing'                                            
    
    In [4]: for t in md.parse(src): 
       ...:     if t.type == 'inline': 
       ...:         for c in t.children: 
       ...:             print(c) 
       ...:                                                                                                        
    Token(type='text', tag='', nesting=0, attrs=None, map=None, level=0, children=None, content='this is a ', markup='', info='', meta={}, block=False, hidden=False)
    Token(type='image', tag='img', nesting=0, attrs=[['src', 'test.png'], ['alt', ''], ['title', 'so nice']], map=None, level=0, children=[Token(type='text', tag='', nesting=0, attrs=None, map=None, level=0, children=None, content='picture', markup='', info='', meta={}, block=False, hidden=False)], content='', markup='', info='', meta={}, block=False, hidden=False)
    Token(type='text', tag='', nesting=0, attrs=None, map=None, level=0, children=None, content=' of a thing', markup='', info='', meta={}, block=False, hidden=False)
    
    In [5]: md.options['store_labels'] = True                                                                      
    
    In [6]: for t in md.parse(src): 
       ...:     if t.type == 'inline': 
       ...:         for c in t.children: 
       ...:             print(c) 
       ...:                                                                                                        
    Token(type='text', tag='', nesting=0, attrs=None, map=None, level=0, children=None, content='this is a ', markup='', info='', meta={}, block=False, hidden=False)
    Token(type='image', tag='img', nesting=0, attrs=[['src', 'test.png'], ['alt', ''], ['title', 'so nice']], map=None, level=0, children=[Token(type='text', tag='', nesting=0, attrs=None, map=None, level=0, children=None, content='picture', markup='', info='', meta={}, block=False, hidden=False)], content='', markup='', info='', meta={}, block=False, hidden=False)
    Token(type='text', tag='', nesting=0, attrs=None, map=None, level=0, children=None, content=' of a thing', markup='', info='', meta={}, block=False, hidden=False)
    

    Expected behavior

    Image tokens should have their alt attribute set here: https://github.com/executablebooks/markdown-it-py/blob/16b85370f6ef538b50d4da15fa883e05be258c75/markdown_it/rules_inline/image.py#L140

    And the store_labels option should add labels to inline links/images that aren't declared as references.

    Bonus: does the label still need to be upper-cased in Python? https://github.com/executablebooks/markdown-it-py/blob/16b85370f6ef538b50d4da15fa883e05be258c75/markdown_it/common/utils.py#L337

    enhancement 
    opened by elespike 9
  • Fix the more obscure backslash escape tests

    Fix the more obscure backslash escape tests

    These are the final tests that need to be fixed; one that is directly applicable to CommonMark compliance, and the others are for additional compliance with markdown-it. They are all to do with how \ escapes are treated for some of the more obscure cases in link titles / code fence languages, e.g. [](<\&quot;> "\&amp;\&ouml;")

    • [x] https://github.com/ExecutableBookProject/markdown-it-py/blob/bc799d47e219fac146dd7f38f30641fb295a16fd/tests/test_cmark_spec/test_spec.py#L23
    • [ ] https://github.com/ExecutableBookProject/markdown-it-py/blob/bc799d47e219fac146dd7f38f30641fb295a16fd/tests/test_port/test_fixtures.py#L28
    • [ ] https://github.com/ExecutableBookProject/markdown-it-py/blob/bc799d47e219fac146dd7f38f30641fb295a16fd/tests/test_port/test_fixtures.py#L53
    • [ ] https://github.com/executablebooks/markdown-it-py/pull/140/commits/f0c96ae5dbbbf0d27ed44e2f6ac237662a57001d (from https://github.com/markdown-it/markdown-it/commit/f156ed1bffec0e02b2353abf248c5b10c6101524)
    bug help wanted 
    opened by chrisjsewell 9
  • Catch up with markdown-it v12.0.4

    Catch up with markdown-it v12.0.4

    A continuation on https://github.com/executablebooks/markdown-it-py/pull/109 (based on the branch there). Adds the changes in https://github.com/markdown-it/markdown-it/compare/11.0.1...12.0.4 on top

    https://github.com/executablebooks/markdown-it-py/pull/109 can be merged first and then this one (to make review easier), or this can be merged directly.

    opened by hukkin 8
Releases(v2.1.0)
  • v2.1.0(Apr 16, 2022)

    What's Changed

    • ๐Ÿ”ง MAINTAIN: Add a profiler tox env by @hukkin in https://github.com/executablebooks/markdown-it-py/pull/197
    • ๐Ÿ”ง MAINTAIN: Update performance benchmark by @hukkin in https://github.com/executablebooks/markdown-it-py/pull/196
    • โœจ NEW: Save ordered list numbering by @hukkin in https://github.com/executablebooks/markdown-it-py/pull/192
    • โฌ†๏ธ UPGRADE: Drop support for EOL Python 3.6 by @hukkin in https://github.com/executablebooks/markdown-it-py/pull/194
    • ๐Ÿงช TEST: Space in link destination generates IndexError by @mib112 in https://github.com/executablebooks/markdown-it-py/pull/206
    • ๐Ÿ“š DOCS: Fix typos by @kianmeng in https://github.com/executablebooks/markdown-it-py/pull/203
    • ๐Ÿ”ง MAINTAIN: Move from setuptools to flit by @chrisjsewell in https://github.com/executablebooks/markdown-it-py/pull/208
    • ๐Ÿ“š DOCS: Fix build by @chrisjsewell in https://github.com/executablebooks/markdown-it-py/pull/209
    • ๐Ÿ”ง MAINTAIN: Add isort hook by @chrisjsewell in https://github.com/executablebooks/markdown-it-py/pull/210
    • โ™ป๏ธ REFACTOR: Move internal Rule/Delimiter to dataclass by @chrisjsewell in https://github.com/executablebooks/markdown-it-py/pull/211
    • โ™ป๏ธ REFACTOR: Move Token to dataclass by @chrisjsewell in https://github.com/executablebooks/markdown-it-py/pull/212
    • ๐Ÿ“š DOCS: Update usage guide to use PyPI package name by @thibaudcolas in https://github.com/executablebooks/markdown-it-py/pull/202
    • ๐Ÿ› FIX: Combination of blockquotes, list and newlines causes IndexError by @hukkin in https://github.com/executablebooks/markdown-it-py/pull/207
    • โ™ป๏ธ REFACTOR: slots for dataclasses by @hukkin in https://github.com/executablebooks/markdown-it-py/pull/214
    • ๐Ÿš€ RELEASE: v2.1.0 by @chrisjsewell in https://github.com/executablebooks/markdown-it-py/pull/213

    New Contributors

    • @mib112 made their first contribution in https://github.com/executablebooks/markdown-it-py/pull/206
    • @kianmeng made their first contribution in https://github.com/executablebooks/markdown-it-py/pull/203
    • @thibaudcolas made their first contribution in https://github.com/executablebooks/markdown-it-py/pull/202

    Full Changelog: https://github.com/executablebooks/markdown-it-py/compare/v2.0.1...v2.1.0

    Source code(tar.gz)
    Source code(zip)
  • v2.0.1(Jan 24, 2022)

    What's Changed

    • ๐Ÿ› FIX: Crash when file ends with empty blockquote line by @hukkin in https://github.com/executablebooks/markdown-it-py/pull/186
    • โœจ NEW: Add inline_definitions option by @chrisjsewell in https://github.com/executablebooks/markdown-it-py/pull/187

    Full Changelog: https://github.com/executablebooks/markdown-it-py/compare/v2.0.0...v2.0.1

    Source code(tar.gz)
    Source code(zip)
  • v2.0.0(Dec 3, 2021)

    What's Changed

    • โฌ†๏ธ Update: Sync with markdown-it v12.1.0 and CommonMark v0.30 by @hukkin in https://github.com/executablebooks/markdown-it-py/pull/168
    • ๐Ÿ“š DOCS: Fix parameter-names and descriptions by @marcusatiliusregulus in https://github.com/executablebooks/markdown-it-py/pull/173
    • ๐Ÿงช TESTS: Test against python3.10 by @hukkin in https://github.com/executablebooks/markdown-it-py/pull/178
    • ๐Ÿงช TESTS: Add URL normalisation xfail by @hukkin in https://github.com/executablebooks/markdown-it-py/pull/170
    • ๐Ÿ› FIX: Always suffix indented code block with newline by @hukkin in https://github.com/executablebooks/markdown-it-py/pull/169
    • ๐Ÿ‘Œ IMPROVE: Use all to signal re-exports by @hukkin in https://github.com/executablebooks/markdown-it-py/pull/120
    • โ™ป๏ธ REFACTOR: Port mdurl and punycode for URL normalisation by @hukkin in https://github.com/executablebooks/markdown-it-py/pull/171
    • ๐Ÿ”ง MAINTAIN: Use pyproject-build for package deployment by @hukkin in https://github.com/executablebooks/markdown-it-py/pull/177
    • ๐Ÿ“š DOCS: punycode and mdurl are now used by @hukkin in https://github.com/executablebooks/markdown-it-py/pull/179
    • ๐Ÿงช TESTS: Remove needless xfail by @hukkin in https://github.com/executablebooks/markdown-it-py/pull/180
    • โ™ป๏ธ REFACTOR: Remove AttrDict by @chrisjsewell in https://github.com/executablebooks/markdown-it-py/pull/181
    • ๐Ÿš€ RELEASE: v2.0.0 by @chrisjsewell in https://github.com/executablebooks/markdown-it-py/pull/182

    New Contributors

    • @marcusatiliusregulus made their first contribution in https://github.com/executablebooks/markdown-it-py/pull/173

    Full Changelog: https://github.com/executablebooks/markdown-it-py/compare/v1.1.0...v2.0.0

    Source code(tar.gz)
    Source code(zip)
  • v1.0.0(May 2, 2021)

  • v0.5.4(Sep 8, 2020)

  • v0.4.9(Aug 11, 2020)

  • v0.4.0(Mar 28, 2020)

Owner
Executable Books
An open collaboration to create executable books with Jupyter
Executable Books
Convert mind maps to markdown for import into Roam.

Mind Map to Markdown for Roam import Got a Mind Map with contents you'd like to import into Roam? Soon, this Python application might do what just you

Romilly Cocking 3 Dec 09, 2021
A automated python script that creates mark-down files to read for the aes keys and other useful information.

Archive A automated python script that creates mark-down files to read for the aes keys and other useful information. Table of Contents Benbot Automat

Tector 13 Dec 14, 2022
Mdformat is an opinionated Markdown formatter that can be used to enforce a consistent style in Markdown files

Mdformat is an opinionated Markdown formatter that can be used to enforce a consistent style in Markdown files. Mdformat is a Unix-style command-line tool as well as a Python library.

Executable Books 180 Jan 06, 2023
Preview GitHub README.md files locally before committing them.

Grip -- GitHub Readme Instant Preview Render local readme files before sending off to GitHub. Grip is a command-line server application written in Pyt

Joe Esposito 5.9k Jan 08, 2023
A markdown generation library for Python.

Welcome to SnakeMD SnakeMD is your ticket to generating Markdown in Python. To prove it to you, we've generated this entire README using SnakeMD. See

The Renegade Coder 22 Dec 08, 2022
Application that converts markdown to html.

Markdown-Engine An application that converts markdown to html. Installation Using the package manager [pip] pip install -r requirements.txt Usage Run

adriano atambo 1 Jan 13, 2022
Remarkable Markdown Debian Package Fix

Remarkable debian package fix For some reason the Debian package for remarkable markdown editor has not been made to install properly on Ubuntu 20.04

Eric Seifert 37 Jan 02, 2023
Markdown Presentations for Tech Conferences, Training, Developer Advocates, and Educators.

March 1, 2021: Service on gitpitch.com has been shutdown permanently. GitPitch 4.0 Docs Twitter About Watch the Introducing GitPitch 4.0 Video Visit t

David Russell 5.4k Jan 05, 2023
A Discord Bot for rendering Markdown

Markdown to PDF Bot A discord bot that accepts markdown files (or messages) and displays them as images. Prerequisite To install, you must have have :

1 Oct 21, 2021
A fast, extensible and spec-compliant Markdown parser in pure Python.

mistletoe mistletoe is a Markdown parser in pure Python, designed to be fast, spec-compliant and fully customizable. Apart from being the fastest Comm

Mi Yu 546 Jan 01, 2023
Provides syntax for Python-Markdown which allows for the inclusion of the contents of other Markdown documents.

Markdown-Include This is an extension to Python-Markdown which provides an "include" function, similar to that found in LaTeX (and also the C pre-proc

Chris MacMackin 85 Dec 30, 2022
Notedown - Markdown <=> IPython Notebook

Python 2/3 and IPython 4 / Jupyter compatible! Convert IPython Notebooks to markdown (and back) notedown is a simple tool to create IPython notebooks

Aaron O'Leary 840 Jan 04, 2023
A lightweight and fast-to-use Markdown document generator based on Python

A lightweight and fast-to-use Markdown document generator based on Python

ๅฟซไน็š„่€้ผ ๅฎๅฎ 1 Jan 10, 2022
Static site generator that supports Markdown and reST syntax. Powered by Python.

Pelican Pelican is a static site generator, written in Python. Write content in reStructuredText or Markdown using your editor of choice Includes a si

Pelican dev team 11.3k Jan 05, 2023
Toci is a markdown tool to generate an outline from a given Jupyter notebook.

Toci is a markdown tool to generate an outline from a given Jupyter notebook. It traverses the markdown cells of a given ipynb file to form a toc for you.

Hakan ร–zler 7 Jan 22, 2022
A markdown extension for converting Leiden+ epigraphic text to TEI XML/HTML

LeidenMark $ pip install leidenmark A Python Markdown extension for converting Leiden+ epigraphic text to TEI XML/HTML. Inspired by the Brill plain te

Andrรฉ van Delft 2 Aug 04, 2021
Rich-cli is a command line toolbox for fancy output in the terminal

Rich CLI Rich-cli is a command line toolbox for fancy output in the terminal, built with Rich. Rich-cli can syntax highlight a large number of file ty

Textualize 2.5k Jan 02, 2023
a small simple library for generating documentation from docstrings

inkpot a small simple library for generating documentation from docstrings inkpot is available on pip. Please give it a star if you like it! To know m

Axel Gard 5 Oct 20, 2022
A fast yet powerful Python Markdown parser with renderers and plugins.

Mistune v2 A fast yet powerful Python Markdown parser with renderers and plugins. NOTE: This is the re-designed v2 of mistune. Check v1 branch for ear

Hsiaoming Yang 2.2k Jan 04, 2023
Livemark is a static page generator that extends Markdown with interactive charts, tables, and more.

Livermark This software is in the early stages and is not well-tested Livemark is a static site generator that extends Markdown with interactive chart

Frictionless Data 86 Dec 25, 2022