Fill workbook by given data into places marked by special placeholders.
Install package via npm:
npm install @tormozz48/xlsx-template
Assume there ./template-simple.xlsx
XLSX file in your working directory with given content:
# | A | B | C | D | E |
---|---|---|---|---|---|
1 | str(data.strVal) | number(data.numberVal 0.00) | date(data.dateVal dd/mm/yyyy) | link(data.linkVal) | {str(data.strVal)} |
2 | number(data.numberVal) | date(data.dateVal) |
const {XLSXPopulateTemplate} = require('xlsx-template');
const xlsxPopulateTemplate = new XLSXPopulateTemplate();
await xlsxPopulateTemplate.loadTemplate('./template-simple.xlsx');
xlsxPopulateTemplate.applyData({
data: {
strVal: 'Some String value',
numberVal: 3.14159,
dateVal: new Date(2020, 0, 6),
linkVal: {text: 'some link', ref: 'http://github.com'}
}
});
await xlsxPopulateTemplate.toFile('./output.xlsx');
Code above will create new file ./output.xlsx
with replacing all placeholders from ./template-simple.xlsx
on provided data.
It also will set valid format to cells according to used placeholders.
# | A | B | C | D | E |
---|---|---|---|---|---|
1 | Some String value | 3,14 | 06/01/2020 | some link | str(data.strVal) |
2 | 3,14159 | 06-01-2020 |
It is possible to fill range of rows by values given as array. For example array of objects such as:
[
{
strVal: 'Github',
numberVal: 134.1222,
dateVal: new Date(2020, 1, 1),
linkVal: {text: 'github', ref: 'https://github.com'}
},
{
strVal: 'Facebook',
numberVal: 4352.232,
dateVal: new Date(2020, 2, 23),
linkVal: {text: 'facebook', ref: 'https://facebook.com'}
},
{
strVal: 'Google',
numberVal: 733.2122321,
dateVal: new Date(2020, 3, 7),
linkVal: {text: 'google', ref: 'https://google.com'}
}
]
applied to following template:
# | A | B | C | D |
---|---|---|---|---|
1 | str(data[i].strVal) | number(data[i].numberVal 0.00) | date(data[i].dateVal dd/mm/yyyy) | link(data[i].linkVal) |
will fill first three rows by corresponded values from data array:
# | A | B | C | D |
---|---|---|---|---|
1 | Github | 134,12 | 01/02/2020 | github |
2 | 4352,23 | 23/03/2020 | ||
3 | 733,21 | 07/04/2020 |
Paste given value to a cell marked with placeholder and use default cell string formatter.
# | A |
---|---|
1 | str(data.foo) |
xlsxPopulateTemplate.applyData({data: {foo: 'Hello World'}});
# | A |
---|---|
1 | Hello World |
Paste given value to a cell and use number formatter. Optionally use second argument of number placeholder function to specify number format which should be applied to cell value.
# | A |
---|---|
1 | number(data.foo, 0.00) |
xlsxPopulateTemplate.applyData({data: {foo: 3.14159}});
# | A |
---|---|
1 | 3.14 |
Paste given value to a cell and use date formatter. Optionally use second argument of date placeholder function to specify
date format which should be applied to cell value. Default date format is dd-mm-yyyy
.
# | A |
---|---|
1 | date(data.foo dd/mm/yyyy) |
xlsxPopulateTemplate.applyData({data: {foo: new Date(2020, 0, 9)}});
# | A |
---|---|
1 | 09/01/2020 |
Create link value in cell with placeholder. Needs to receive data item as object with fields: text
and ref
where text
- is
link text representation and ref
- is link reference url.
# | A |
---|---|
1 | link(data.foo) |
xlsxPopulateTemplate.applyData({data: {foo: {text: 'Github', ref: 'https://github.com'}}});
# | A |
---|---|
1 | Github |
A special formatter which allows to simply expand inner placeholder without appliyng it. It is useful when there you need to fill template with some part of needed data at first stage and then fill rest of data at second stage.
# | A |
---|---|
1 | {str(data.foo)} |
xlsxPopulateTemplate.applyData({});
After first call it simply expand inner placeholder str(data.foo)
so it will be ready to use on next call.
# | A |
---|---|
1 | str(data.foo) |
xlsxPopulateTemplate.applyData({data: {foo: 'Hello World'}});
# | A |
---|---|
1 | Hello World |
To fill multiple rows below by corresponded array items you should use [i]
to mark data node
that should be applied as array of items.
# | A |
---|---|
1 | str(data[i].name) |
xlsxPopulateTemplate.applyData({data: [
{name: 'Github'},
{name: 'Facebook'},
{name: 'Google'}
]);
# | A |
---|---|
1 | Github |
2 | |
3 |
Async function to load XLSX workbook from buffer of file or event create it from scratch. Loads XLSX workbook from file:
const xlsxPopulateTemplate = new XLSXPopulateTemplate();
await xlsxPopulateTemplate.loadTemplate('./template-simple.xlsx');
Loads XLSX workbook from buffer:
const buffer = await fs.readFile('./template-simple.xlsx');
const xlsxPopulateTemplate = new XLSXPopulateTemplate();
await xlsxPopulateTemplate.loadTemplate(buffer);
Creates XLSX workbook from scratch (empty workbook)
const xlsxPopulateTemplate = new XLSXPopulateTemplate();
await xlsxPopulateTemplate.loadTemplate();
Fills matched template placeholders with given data.
const xlsxPopulateTemplate = new XLSXPopulateTemplate();
await xlsxPopulateTemplate.loadTemplate();
xlsxPopulateTemplate.applyData({foo: 'bar'})
Async function which serializes current workbook into buffer.
const xlsxPopulateTemplate = new XLSXPopulateTemplate();
await xlsxPopulateTemplate.loadTemplate();
const buffer = await xlsxPopulateTemplate.toBuffer();
Async function which saves XLSX workbook into file with given filePath on local filesystem.
const xlsxPopulateTemplate = new XLSXPopulateTemplate();
await xlsxPopulateTemplate.loadTemplate();
await xlsxPopulateTemplate.toFile('./my-awesome.xlsx');
Getter which simply returns XLSX workbook instance of xlsx-populate2 package. It is usefull for direct manipulation with workbook or it inner parts like cells, rows and columns.
const xlsxPopulateTemplate = new XLSXPopulateTemplate();
await xlsxPopulateTemplate.loadTemplate();
const workbook = xlsxPopulateTemplate.workbook;
workbook.sheet('Sheet1').cell('A1').value('Foo');
Some useful commands for development:
npm run build
- compiles typescript code into javascript code.npm run clean
- cleans js dist folder with compiled javascript code.npm run format
- performs code formatting via prettier tool.npm run lint
- runs tslint syntax checker.npm run test
- runs mocha tests.npm run test -watch
- runs mocha tests in "watch" mode. Launch tests on every code change.npm run test -cov
- runs mocha tests with coverage calculation.