Skip to main content

A Markdown to GitHub-style HTML file conversion utility.

Project description

A Markdown to GitHub-style HTML file conversion utility

PyPI - Version PyPI - Implementation PyPI - Python Version PyPI - Status Static Badge Static Badge Static Badge Documentation Status PyPI - License PyPI - Wheel

Overview

ghmdlib (GitHub Markdown Library) is a light-weight and simple command line utility (and back-end library) designed to convert Markdown files into GitHub Flavoured HTML. It does so by using the GitHub Markdown API in combination with GitHub Markdown CSS.

[!NOTE] This project is a fork of the original ghmd utility (commit 8f6a0ff), and updated to include the following features:

  • A back-end library providing callable conversion functionality to your Python applications.
  • An 'offline' mode for sensitive environment deployment (or limited internet connectivity).
  • Preview functionality which auto-opens converted documents in a web browser for quick viewing.

As an aside, the ghmdlib command line utility was used for proofing this README.md file, using the following command:

$ ./ghmd.py ../README.md --preview 

Quickstart

Installation

To install ghmdlib, first activate your target virtual environment, then use pip:

pip install ghmdlib

This will install both the library and the command line utility.

For older releases, visit PyPI or the GitHub Releases page.

Command Line Utility Usage

Simply run ghmdlib with the path to the markdown file(s) you want to convert. An HTML file will be created in the same directory as the original markdown file with the same filename, using an .html file extension.

For example:

ghmd /path/to/my-file.md

Library Usage

To integrate the Markdown to HTML converter into a Python project, the library can be called as:

from ghmdlib import converter

# Convert a Markdown file with auto-open preview.
converter.convert(path='/path/to/my-file.md', preview=True)

Command Line Utility Options

Help Menu: --help

The help menu can be accessed at any time using the following. This provides an overview of the tool's capabilities and available options.

ghmd --help

Offline Mode: --offline

If using ghmdlib in a sensitive environment, or without internet connectivity, the CLI utility and library can be used offline, making use of the pre-downloaded CSS files (for both the dark and light themes), and the mdtex2html library for Markdown to HTML conversions, rather than calling the GitHub API.

Themes: --dark and --light

The default CSS styles adapt to the system's dark mode setting of the reader. If you want to force the CSS to be light or dark, you can use the --light or --dark options.

For example, to render the Markdown file in dark mode, you can use:

ghmd /path/to/my-file.md --dark

Both --light and --dark can be used in combination with --embed-css.

Embedded CSS: --embed-css

By default, ghmdlib will add the remote CSS as a <link> tag in the HTML file. If you want to embed the CSS directly into the HTML file so that, for example, you can send the HTML file to someone else and they can view it without an internet connection, you can use the --embed-css option.

ghmd /path/to/my-file.md --embed-css

Plain Markdown: --no-gfm

The tool offers two modes: GitHub Flavored Markdown (gfm by default) and plain Markdown. To use the latter, the --no-gfm option can be used:

ghmd /path/to/my-file.md --no-gfm

GitHub API Token

By default, ghmdlib uses unauthenticated requests to the GitHub API, which has a rate limit of 60 requests per hour. To increase this limit to 5000 requests per hour, you can set the GITHUB_TOKEN environment variable with a GitHub personal access token:

export GITHUB_TOKEN=your_github_token_here

To create a personal access token, visit your GitHub Settings > Developer Settings > Personal access tokens and create a new token (no specific scopes are required).

Using the Library

The documentation suite provides detailed explanations and usage examples for each importable module. For in-depth documentation, code examples, and source links, refer to the Library API page.

A search field is available in the left navigation bar to help you quickly locate specific modules or methods.

Troubleshooting

No troubleshooting guidance is available at this time.

For questions not covered here, or to report bugs, issues, or suggestions, please open an issue on GitHub.

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

ghmdlib-0.1.0.tar.gz (8.2 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ghmdlib-0.1.0-py3-none-any.whl (23.7 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: ghmdlib-0.1.0.tar.gz
  • Upload date:
  • Size: 8.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.13.7

File hashes

Hashes for ghmdlib-0.1.0.tar.gz
Algorithm Hash digest
SHA256 a7967c1e6ef5780d2d8b3abe9dc2f917315c765823705f5842e20396005f786d
MD5 d938ba6a1ec86ac7595f2db7e5bd08a2
BLAKE2b-256 ed5a93e35b3641a243df359b6b6fe49647f455133fc58c4f6813ef506de9bb93

See more details on using hashes here.

File details

Details for the file ghmdlib-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: ghmdlib-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 23.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.13.7

File hashes

Hashes for ghmdlib-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5d09c8f27ca0fe071952819fcce34241015200b48b2128a7bd6e49483708dd4d
MD5 878ce6468c022c345e6996de49b5c4be
BLAKE2b-256 79b8789e2fb7271d7fa0aa80b4f4bb6c26ec0b8c7b71b1b248ae1e357735202b

See more details on using hashes here.

Supported by

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