rst2pdf

Use a text editor. Make a PDF

Welcome to rst2pdf

The rst2pdf tool creates PDF documents from your ReStructured Text markup. It is an Open Source, free-to-use tool that will help you create documents, slide decks and other PDF output very quickly and easily.

Why rst2pdf?

Simple and quick to create Open your preferred text editor, capture your thoughts, and generate to a professional-looking document.

Separate content and presentation Slide deck needs to be higher contrast? Apply a different style and re-generate. Updated branding? Create one new style and apply to all PDFs.

Source Control Collaborate easily with others or simply keep easy track of your own work as you go.

Open Source Free to use and free to change - the tool, the styles you use, it’s all yours!

Getting Started

To create your first PDF, simply install the rst2pdf tool, write some text, and create the first document.

Install rst2pdf

rst2pdf requires Python 3.9 or greater.

Option 1: install with pipx

This is the easiest option and will give the most recent stable release.

pipx install rst2pdf

rst2pdf also has support for a number of features that require additional dependencies. Installation of all the required dependencies using pipx may be installed using:

pipx install rst2pdf[aafiguresupport,mathsupport,plantumlsupport,rawhtmlsupport,sphinx,svgsupport]

Option 2: install from source

Choose this option if you want the newest features, or to contribute to the project.

git clone https://github.com/rst2pdf/rst2pdf
cd rst2pdf
uv sync --all-extras

If you don’t have uv, please see the uv installation docs.

Start using rst2pdf

Start with a text file. rst2pdf uses ReStructured Text which is a markup format similar to (but a bit more detailed than) markdown. Here’s an example file to get you started:

PDF Documents From Your Text Editor
###################################

This tool uses a plain text format for content, then applies styles to make the nice document you see here.

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aliquam maximus tortor sem, vel pellentesque leo fringilla et. Aliquam imperdiet nisi eget dui finibus sagittis. Nunc malesuada libero vel dignissim pharetra. Cras egestas vehicula quam, et accumsan arcu lacinia auctor. Integer imperdiet sagittis justo, vel varius nulla dapibus finibus. Cras rhoncus mattis pellentesque. Quisque vel sapien sed tellus convallis accumsan. Praesent volutpat sapien at lacinia scelerisque. Phasellus neque libero, consectetur in neque id, egestas elementum nisl.

Mauris eu dolor non massa auctor suscipit. Donec sit amet aliquet eros, id sodales leo. Duis erat ipsum, laoreet eget nulla at, euismod ullamcorper mi. Curabitur vel orci a libero ullamcorper finibus. Sed vel lectus sapien. Praesent mollis et dui at laoreet. Donec eleifend, nunc nec bibendum luctus, massa lorem vestibulum justo, a convallis nunc turpis ut urna. Proin venenatis erat et ante convallis efficitur. Lorem ipsum dolor sit amet, consectetur adipiscing elit. In neque turpis, sollicitudin maximus egestas sed, finibus a odio. Nam eu eros id enim vehicula hendrerit at vel orci. Curabitur volutpat tempor purus ut auctor. Mauris vulputate sollicitudin porttitor. Nunc consectetur lectus nibh, et commodo purus porttitor ut. Nulla facilisi.

Further Sections, Headings, etc
===============================

Sed id interdum quam. Donec suscipit, justo ac blandit vestibulum, massa est semper dolor, vel sodales nulla metus eu purus. In risus tortor, interdum pellentesque dolor a, rhoncus volutpat orci. Ut commodo purus orci, non aliquet massa maximus in. Morbi semper dui ipsum, a dictum nisi pretium ut. Vestibulum bibendum lacinia viverra. In hac habitasse platea dictumst. Nunc vestibulum maximus mollis. Cras suscipit dictum condimentum. Nam vulputate, enim at gravida placerat, tellus nibh accumsan ligula, auctor ornare purus leo ac orci. Quisque ultricies dictum purus. In facilisis feugiat suscipit.

Save this file as sample.rst and generate PDF with this command:

rst2pdf sample.rst

Check for a new file called sample.pdf - and you are already on your rst2pdf journey!

Tips, Tricks and Tools

There are a few other PDF tools that we use and love, they are included here in case you need them too!

Tools we use While Building

nodemon https://nodemon.io

Useful for watching for changed files and then automatically recompiling a PDF. For example:

nodemon --ext rst,style --exec 'rst2pdf input.rst'

Working with PDF Files

pdftk: The PDF Toolkit https://www.pdflabs.com/tools/pdftk-the-pdf-toolkit/

This commandline tool allows you to combine PDFs (useful for adding coversheets), extract and change metadata such as bookmarks, and much more.

pdfjam https://warwick.ac.uk/fac/sci/statistics/staff/academic-research/firth/software/pdfjam/

Very useful for resizing and scaling PDFs, and printing handouts with multiple slides per page.

Try the example below for 12 slides per page, A4 landscape (also ideal for checking that the fonts are large enough, you should be able to read this when printed …)

pdfjam --suffix handout --nup '4x3' --frame 'true' --noautoscale 'false' --delta '0.2cm 2cm' --scale '0.9' --landscape -- ${FILE}.pdf -

Imagemagick https://www.imagemagick.org

Can treat PDFs as images, very useful for creating previews, thumbnails, or tweetable versions of slides …

Presenting with PDF

PDF Presenter Console https://pdfpc.github.io/

screenshot of pdfpc in action

Available for most Linux flavours (on Ubuntu, apt-get install pdf-presenter-console) and is also open source so you can patch if required.

Presentation.app http://iihm.imag.fr/blanch/software/osx-presentation/

speaker view screen of presentation.app

For OSX, this is a great Keynote-alternative for presenter view and notes.