This package provides a command-line interface to manage multilingual contents and generate i18n markdown from a single base file.
🌏 English | Français | 한국어 | 日本語
Available in Bash, Zsh, and Windows PowerShell.
Table of Contents ⚡
By managing only one Base file, we can reduce the number of errors caused by missing or mismatched translations. Additionally, thanks to editing in a single file, we can expect convenient translation with the auto-completion function of AI tools such as Copilot.
Markdown:
Jupyter Notebook:
Supports the following features:
- Markdown, Jupyter Notebook(
.ipynb
) as input formats - As-is, HTML, PDF as ouput formats
- Command-line interface for Bash, Zsh, Windows PowerShell
- Python API
- Recursive traversal mode with
-r
option (As-is, HTML, PDF are all supported) - Batch processing mode with YAML file (Only
As-is
is supported) - IETF language tags
- UTF-8 encoding
- Automatic generation of table of contents with level and emoji options (Markdown and Jupyter Notebook are both supported)
- Base file validation (Check the number of tags of each language)
- Validation only mode for CI/CD (Disable file generation)
pip3 install mmg
pip3 install mmg
If you have any issues with WeasyPrint, install it with the following command. WeasyPrint is only used to create PDFs.
brew install weasyprint
-
MMG uses WeasyPrint to create PDFs. WeasyPrint requires the GTK library, so download and run the latest GTK3 installer. If you are not interested in creating PDFs, you can skip this step. Other features of MMG are available without GTK.
-
Install MMG using Pip.
pip3 install mmg
Please refer to the documentation for detailed usage and examples.
$ mmg --help
Usage: mmg [OPTIONS] [FILE_NAMES]...
FILE_NAMES: Base file names to convert. `*.base.md` or `*.base.ipynb` are
available.
Here are some examples:
mmg *.base.md
mmg *.base.ipynb
mmg *.base.md *.base.ipynb -o pdf --css github-dark
mmg --recursive
mmg --recursive --validation-only
mmg --batch mmg.yml
Options:
-r, --recursive This will search all subfolders based on
current directory.
-b, --batch FILE YAML file path for batch conversion.
(Default: None)
-o, --output-format [as-is|html|pdf]
Output format. (Default: as-is)
--css TEXT CSS file path or preset('github-
light'/'github-dark'). Only for the HTML/PDF
output. (Default: github-light)
-y, --yes This will confirm the conversion without
asking. (Default: False)
-s, --skip-validation Skip the health check. (Default: False)
--validation-only Only check the health. (Default: False)
-v, --verbose Verbosity level from 0 to 2. --verbose:1,
-v:1, -vv:2 (Default: 0)
--version Show the current version.
--help Show this message and exit.
Please refer to the troubleshooting page on the website.
Made with contrib.rocks.
If you are interested in how to contribute, please refer to the contribution guide.