Templating and pdf generation for docx/pptx files
Project description
=========
Burocracy
=========
Burocracy is a library that allows you to use .docx templates as
templates using MailMerge fields and can save them as docx's or pdfs. It
can insert plain text, images, tables and (simple) HTML. See
`django-bureaucracy`_ for some mild django integration.
WIP: PPTX as templates.
Usage
=====
Example
-------
.. code-block::
from bureaucracy import DocxTemplate, HTML, Image, Table
doc = DocxTemplate('examples/sample.docx')
context = {
'table': Table(data=[['this is the first cell of the first row', 'this is the second cell of the first row'],
['the second row', 'etc'],
['etc', 'etc]],
headers=['header 1', 'header 2']),
'image': Image('pigeon.jpg')
'html': HTML(<p><strong>bold</strong>-notbold</p><ul><li>hop</li><li>la</li><li>kee</li></ul>")
'text': 'some text',
}
doc.render_and_save('generated.docx', context)
doc.render_and_save('generated.pdf', context, format='pdf')
Inserting mail merge fields
---------------------------
Bureaucracy expects the .docx-files passed to the ``DocxTemplate`` constructor
to contain MailMerge fields whose names correspond to the ones used
in the context dict. How this is done exactly depends on the version of
Office you have, but it seems that it's always a variation on
Insert > Field > Mail Merge > Mergefield and then entering the name:
.. figure:: docs/mailmerge_mac.png?raw=true
:alt: Mailmerge on Mac
What it looks like on Office Mac 2015
Installation
============
.. code-block:: bash
pip install burocracy
Note that although this will install the pypandoc dependency, that package
makes use of the pandoc executable whose installation sometimes fails.
To work around this, install pandoc on it's own with your favorite package
manager and make it available on the path.
For the pdf generation, bureaucracy needs the LibreOffice ``soffice`` executable
to be installed and on the path.
.. _django-bureacracy: https://bitbucket.org/maykinmedia/django-bureaucracy
Burocracy
=========
Burocracy is a library that allows you to use .docx templates as
templates using MailMerge fields and can save them as docx's or pdfs. It
can insert plain text, images, tables and (simple) HTML. See
`django-bureaucracy`_ for some mild django integration.
WIP: PPTX as templates.
Usage
=====
Example
-------
.. code-block::
from bureaucracy import DocxTemplate, HTML, Image, Table
doc = DocxTemplate('examples/sample.docx')
context = {
'table': Table(data=[['this is the first cell of the first row', 'this is the second cell of the first row'],
['the second row', 'etc'],
['etc', 'etc]],
headers=['header 1', 'header 2']),
'image': Image('pigeon.jpg')
'html': HTML(<p><strong>bold</strong>-notbold</p><ul><li>hop</li><li>la</li><li>kee</li></ul>")
'text': 'some text',
}
doc.render_and_save('generated.docx', context)
doc.render_and_save('generated.pdf', context, format='pdf')
Inserting mail merge fields
---------------------------
Bureaucracy expects the .docx-files passed to the ``DocxTemplate`` constructor
to contain MailMerge fields whose names correspond to the ones used
in the context dict. How this is done exactly depends on the version of
Office you have, but it seems that it's always a variation on
Insert > Field > Mail Merge > Mergefield and then entering the name:
.. figure:: docs/mailmerge_mac.png?raw=true
:alt: Mailmerge on Mac
What it looks like on Office Mac 2015
Installation
============
.. code-block:: bash
pip install burocracy
Note that although this will install the pypandoc dependency, that package
makes use of the pandoc executable whose installation sometimes fails.
To work around this, install pandoc on it's own with your favorite package
manager and make it available on the path.
For the pdf generation, bureaucracy needs the LibreOffice ``soffice`` executable
to be installed and on the path.
.. _django-bureacracy: https://bitbucket.org/maykinmedia/django-bureaucracy
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
burocracy-0.2.1.tar.gz
(13.5 kB
view details)
Built Distribution
burocracy-0.2.1-py3-none-any.whl
(18.0 kB
view details)
File details
Details for the file burocracy-0.2.1.tar.gz
.
File metadata
- Download URL: burocracy-0.2.1.tar.gz
- Upload date:
- Size: 13.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 905f8877b729b8095a9128dd879a11640344c759f5c0ad9e36cfe45643495048 |
|
MD5 | 00260d0b961925538efe240de0d968f3 |
|
BLAKE2b-256 | 74cce148bb5550eae5f0b82d0a11d5ca607c61d8a62f618c0f62d4b0e75facaa |
File details
Details for the file burocracy-0.2.1-py3-none-any.whl
.
File metadata
- Download URL: burocracy-0.2.1-py3-none-any.whl
- Upload date:
- Size: 18.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5ff94d7a5c8cf2dfda36afba267add13e4656a81fad7e77f112fe395939fe96e |
|
MD5 | 55ce95b61b2725694cd3ad5e37aab474 |
|
BLAKE2b-256 | 79328a7d406f6e4434cf9eb1a85a01d04d7533f80c4e4dfc06990994ba56be71 |