Skip to main content

A minimal LaTeX template engine.

Project description

TexRocket

A basic template engine for LaTeX. Create dynamic documents by parsing JSON data and populating a custom template.

The script parses a template and fills it with data read from json files. Provide different json files to have multiple files with the same structure but varying content. Especially useful for translations.

Requirements

Make sure you have the following programs installed on your system before moving forward.

Installation

Easily install TexRocket by using pip

pip install texrocket

Usage

At any time you can run the texrocket script with the -h or --help flag to display usage information

usage: texrocket [-h] [-i INPUT_JSON] [-o OUTPUT_DIR] [-v] input_tex

Dynamic LaTeX generation from JSON, developed by Alberto Mosconi

positional arguments:
  input_tex             the LaTeX template file

options:
  -h, --help            show this help message and exit
  -i INPUT_JSON, --input-json INPUT_JSON
                        the JSON file or directory of files
  -o OUTPUT_DIR, --output-dir OUTPUT_DIR
                        the directory for the output files
  -v, --verbose         print verbose output and save LaTeX logs

An example using all possible arguments is

texrocket TEMPLATE.tex -i input.json -o out/ -v

This will create an out/ folder, with the documents generated using the TEMPLATE.tex template and the values inside input.json

out/
├── source/
│   └── TEMPLATE_input.tex
├── logs/
│   └── TEMPLATE_input.log
└── TEMPLATE_input.pdf

! All the JSON files MUST have the same structure, the engine will create multiple documents (one for each .json file) starting from TEMPLATE.tex.

The generated files have the following naming scheme

<TEMPLATE FILENAME>_<JSON FILENAME>.pdf

If the input JSON file is named main.json then this will not show up

<TEMPLATE FILENAME>.pdf

Syntax

Values

To display a certain JSON value reference it with the following syntax

<section.title>
{
  "section": {
    "title": "The section title",
    "text": "some text"
  }
}

The example above will be rendered as "The section title".

Loops

You can avoid repetition of LaTeX code by using loops, which can be nested

\begin{itemize}
  %startloop: first
  \item <name>
    \begin{itemize}
      %startloop: second
      \item <name>
      %endloop
    \end{itemize}
  %endloop
\end{itemize}
{
  "first": [
    {
      "name": "first main list item",
      "second": [
        { "name": "secondary list item" }
      ]
    },
    {
      "name": "second main list item",
      "second": [
        { "name": "secondary list item" }
      ]
    }
  ]
}

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

texrocket-0.0.5.tar.gz (16.8 kB view hashes)

Uploaded Source

Built Distribution

texrocket-0.0.5-py3-none-any.whl (17.4 kB view hashes)

Uploaded Python 3

Supported by

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