docxtemplater is a library to generate docx/pptx documents from a docx/pptx template. It can replace {placeholders} with data and also supports loops and conditions. The templates can be edited by non-programmers, for example your clients.
- Replace a {placeholder} by a value
- Use loops: {#users} {name} {/users}
- Use loops in tables to generate columns
- Use conditions (if users.length>3) with angular Parsing
- Insert custom XML {@rawXml} (for formatted text for example)
- Installation in node
- Installation in the browser
- Generate a document in node
- Generate a document in the browser
The full documentation of the latest version can be found on read the docs.
See CHANGELOG.md for information about how to migrate from older versions.
A user of docxtemplater named Timofey also created a tool to create documents easily :
You can find the tool at : https://ntsdk.github.io/docxtemplater/docxtemplater-en.html , and a screencast showing how it works at https://www.youtube.com/watch?v=uE9By5zEwss
They are a few similar libraries that work with docx, here’s a list of those I know a bit about:
- docx4j :JAVA, this is probably the biggest docx library out there. They is no built in templating engine, but you can generate your docx yourself programmatically
- docx.js: Javascript in the browser, you can create (not modify) your docx from scratch, but only do very simple things such as adding non formatted text
- xlsx-templater : its working quite well, does the same as here but for xlsx
Functionality can be added with modules. Here is the list of existing modules:
Modules developped by docxtemplater core team members :
- Image module using the syntax:
{%image}
, https://docxtemplater.com/modules/image/ - Html Module to insert formatted text in a docx document https://docxtemplater.com/modules/html/
- Slides Module to create multiple slides dynamically https://docxtemplater.com/modules/slides/
- Subtemplate Module to include a document inside an other document https://docxtemplater.com/modules/subtemplate
- Word-Run Module to include raw runs (<w:r>) inside the document. This makes it possible to include styled text without having to remove the enclosing paragraph like in the {@rawXml} tag. https://docxtemplater.com/modules/subtemplate
- QrCode Module to replace an image, keeping any existing properties https://docxtemplater.com/modules/qrcode
- Error Location Module to show the errors in the template with comments inside the template https://docxtemplater.com/modules/error-location
User contributed modules :
- Chart Module using the syntax:
{$chart}
, user contributed https://github.com/prog666/docxtemplater-chart-module (compatible with v2 only) - Hyperlink module using the syntax:
{^link}
, https://github.com/sujith3g/docxtemplater-link-module (compatible with v2 only)
I can give your company support for installing, extending, answering support questions, or maintaining your app that runs docxtemplater. The support plan is paid per month and can be booked from https://plasso.com/s/ycwo8O3hDH