Important: The package is still in active development, so things might change/break. Note that the package name is being changed from NotebookToLatex.jl to NotebookToLaTeX.jl in order to be more consistent with the naming of other packages in the Julia environment. If you've cloned this repo before that, you might want to delete and clone again.
If you try this package and find some bug, or think of a feature you'd like to have implemented, do not hesitate to open an issue.
This package converts your notebook files (Pluto or Jupyter) to beautiful and simple LaTeX files, that are easy to modify. Thus, making it ideal to write reports, articles or books from notebooks.
Although it's already possible to convert both Pluto and Jupyter notebooks to PDFs, or even to LaTeX (via Pandoc), the PDFs are not very customizable and the LaTeX files are usually very messy. In contrast, NotebookToLaTeX.jl focuses less in generality, and more on opinionated defaults.
The package has it's own implementation to parse Markdown to LaTeX,
e.g. it turns # Example
to \chapter{Example}
. Thus,
one can dive down into the actual Julia code and customize it
for his own preference. Or, submit an issue requesting
the feature. Hopefully, more and more customization will
be possible from the get go as the package evolves.
Another very important point to note is that NotebookToLaTeX.jl uses
julia-mono-listing.
This enables it to produce beautiful Julia code inside the LaTeX pdf.
Note that it requires using lualatex
for compilation.
This package is very simple to use. There is pretty much just one function to be used, i.e.
notebooktolatex
To convert the notebooks just use notebooktolatex("mynotebook.ipynb", template=:book)
.
This will produce a directory ./build_latex/
where the LaTeX files
will be generated. Inside build_latex/
you will have:
build_latex
│ main.tex
│ julia_font.tex
│ julia_listings.tex
│ julia_listings_unicode.tex
│ preface.tex
│
└───figures
│ │ mynotebook_plot1.png
│ └───mynotebook_plot2.png
└───fonts
│ │ JuliaMono_Regular.ttf
│ │ ...
│
└───frontmatter
│ │ titlepage.tex
│ └───copyright.tex
│
└───notebooks
└───mynotebook.tex
Using template=:book
, we get the LaTeX book format, thus, we have a preface.tex
,
a titlepage.tex
and a copyright.tex
page. The notebook will be included
as a chapter. To get your final book pdf, just compile the main.tex
using lualatex
.
In case you want a different project folder, you can run the command with an extra argument providing the target directory for the LaTeX files, e.g.:
`notebooktolatex("mynotebook.ipynb", "./project/",template=:book)`.
This will create a ./project/
folder instead of the ./build_latex
.
If instead you just want a simple report containing the Notebook,
you can use the :article
template.
If you want to convert Pluto notebooks, you have to import Makie.jl
, CairoMakie.jl
and
Plots.jl
, which are the packages used in order to save your figures. The reason for this
is that NotebookToLaTeX.jl uses Requires.jl in order to avoid these packages as dependencies.
Hence, to convert Pluto, you have to run:
using Makie, CairoMakie, Plots
notebooktolatex("myplutonotebook.jl", template=:book)
At the moment, the available templates are:
:book
- The standard LaTeX book template;:mathbook
- Very similar to:book
, but with some extra packages for mathematics;:article
- Simple template using thearticle
document class;:matharticle
- Thearticle
template with extra packages for mathematics.
Read the documentation for more information.