Go to file
Bertrand Benjamin 0a40e132c5 Feat: rename dockerfile from mapytex to usecase 2022-07-19 17:13:23 +02:00
bopytex Feat: activate texenv by default 2022-07-19 16:33:27 +02:00
documentation Remove pyMath occurency 2017-04-17 17:04:14 +03:00
example Refact: move mapytex to usecase and build example 2022-07-19 16:37:14 +02:00
test Feat: rename get_config 2022-07-19 15:15:06 +02:00
.drone.yml Fix: only on tagging? 2020-08-20 16:27:17 +02:00
.gitignore core: remove tests from .gitignore 2022-04-14 11:29:39 +02:00
Dockerfile Feat: make dockerfile to test my workflow 2022-05-09 09:09:38 +02:00
Dockerfile.usecase Feat: rename dockerfile from mapytex to usecase 2022-07-19 17:13:23 +02:00
MANIFEST.in spelling and wrong arg 2015-05-16 10:50:03 +02:00
README.md Doc: update README with docker examples 2022-07-19 16:33:51 +02:00
requirements.txt Feat: Create dockerfile to test in new env 2022-05-04 18:03:58 +02:00
setup.py Feat: dockerfile to test bopytex in new environment 2022-05-08 09:15:13 +02:00

README.md

Bopytex

Build Status

Bopytex is a command line tool which embed python into latex. It uses jinja2 to do so with a modified environnement to match with latex syntax.

Installing

Install and update using pip

pip install -U bopytex

Simple example

% save this as tpl_simple.tex
\documentclass[12pt]{article}

\title{Bopytex example -- {{ number }}}

\begin{document}

\maketitle
%- set a = 10
%- set n = 2
We have two variables
\begin{itemize}
    \item a: \Var{a}
    \item n: \Var{n}
\end{itemize}

%# We can use blocks
\begin{itemize}
%- for i in n
    \item \Var{a}
%- endfor
\end{itemize}


\end{document}

To create a version a this document type this

$ bopytex tpl_simple.tex

How I use it

I build this program to produce individual exams subjects for each of my student with the correction associated. I write a template, and bopytex build subject and correction.

To produce formulas and values, I use an another tool I an developing: mapytex <https://git.opytex.org/lafrite/Mapytex. I am importing it through bopytex_config.py.

# bopytex_config.py
from mapytex import Expression
from random import random

Every variables, objects or function inside this file will be available inside the template.

% tpl_example.tpl
\documentclass[12pt]{article}

\title{Bopytex with Mapytex example -- \Var{ number }}

\begin{document}

\maketitle

%- set e = Expression.random("{a} + {b}")
\Var{e}

\Var{e.simplify()}

\end{document}

Then I can produce multiple documents (3 here)

$ bopytex tpl_simple.tex -q 3 -c bopytex_config.py