windows&lunix下node.js实现模板化生成word文件
最近在做了一个小程序!里面有个功能就是根据用户提交的数据,自动生成一份word文档返回给用户。我也是第一次做这功能,大概思路就是先自己弄一份word模板,后台接受小程序发过来的数据,再根据这些数据将相应内容写入到相应位置,再将生成word文档的地址返回给前台,前台再根据返回的URL访问服务器的上对应资源。
由于我的后台用的是node.js 毕竟算是新生语言,插件还是比较少。所以在这里总结一下,以便以后再次用到方便查看。
在windows上动态生成模板word文档。
在windows上实现这个倒是挺容易,因为windows上装有了office这些解析word文档的软件,直接可以进行读写。
这里用到的插件是docx-templates ,直接npm 下载安装就行。
使用起来也挺简单,一开始要声明插入的变量 ,然后根据变量位置直接替换你想要的数据即可。
word模板文件:
+++QUERY
query getData() {
userId
userName
userSummary
userImg
}
+++ 用户ID: +++=userId+++
用户名: +++=userName+++
用户介绍:+++=userSummary+++
用户头像: +++=userImg+++
node.js实现
先在当前文件夹安装docx-templates插件
npm install docx-templates
后端代码
let createReport = require('docx-templates');
createReport({
template: path.join(__dirname, '../data/template/模板2.docx'),
output: path.join(__dirname, '../data/out/结果2.docx'),
data: {
userId: '24',
userName: '斌果',
userSummary: '我介绍你个鬼哟!',
userImg: {
width: 6,
height: 6,
path: path.join(__dirname, '../data/image1.png'),
extension: '.png'
}
}
});
在Lunix上动态生成模板word文档。
首先,容我说下在lunix上处理遇到的坑吧!
由于lunix系统的处理.docx文件的格式和window下不同,没有office帮我们解析文件,我们是无法正常打开,要使用xzvf解压后才能看到.docx文件的真面目。
当我tar了下.docx文件之后

what???? 这是什么鬼东西 怎么都变成xml格式的呢?
其实,word文档本来就是这个样子,只是在windows下被系统办公软件解析罢了。
然后我不管三七二十一了,直接用windows上的方法,用docx-templates处理。
然后处理是处理了 而且没报错, 但是 生成出来的文件是这样的!

W T F??? 全是十进制乱码!
然后又百度了一下说lunix上读写格式和window不一样,说可以用offenoffice插件对word文档进行解析。
然后我又在服务器上安装配置了openoffice,遇到服务启动不了等各种坑最后貌似成功启动了openoffice服务,
最后发现,W T F 出来的文件还是十进制乱码!。。。。。。。。。。。。。
没办法 只好再去百度,java啊 php啊 python啊 都有,为毛线不见node处理方法。。。。
解决方法
辗转反侧,最后终于找到了解决方法 就是 docxtemplater 而且 它在window和lunix下都可以正常处理
这是官网:https://docxtemplater.readthedocs.io/en/latest/
使用起来也很简单,首页安装docxtemplater
npm install docxtemplater
npm install jszip@2
npm install jszip-utils # only for the browser (webpack)
接着很简单 ,自己创建一份模板文件(因为这个插件主要是用JSON作为数据输入,因此它也可以很容易在其他语言中使用。)
用户ID:{userId}
用户姓名:{userName}
接着直接上代码就好!
let JSZip = require('jszip');
let Docxtemplater = require('docxtemplater');
let fs = require('fs');
let path = require('path');
let content = fs
.readFileSync(path.resolve(__dirname, 'practice1.docx'), 'binary');
let zip = new JSZip(content);
let doc = new Docxtemplater();
doc.loadZip(zip);
doc.setData({
userId: '24',
userName:'斌果'
});
try {
doc.render()
}
catch (error) {
let e = {
message: error.message,
name: error.name,
stack: error.stack,
properties: error.properties,
}
console.log(JSON.stringify({error: e}));
throw error;
}
let buf = doc.getZip()
.generate({type: 'nodebuffer'});
fs.writeFileSync(path.resolve(__dirname, 'output.docx'), buf);
这样就顺利解决了!
windows&lunix下node.js实现模板化生成word文件的更多相关文章
- Windows 7 下 Node.js 连接 Oracle
原创作者: sailtseng 1. 安装 Oracle 11g express 详见: <Windows 7 x64 安装 Oracle 11g Express> 2. 安装 Micr ...
- Windows 7下Node.js Web开发环境搭建笔记
Node.js是什么? 我们看看百科里怎么说的?JavaScript是一种运行在浏览器的脚本,它简单,轻巧,易于编辑,这种脚本通常用于浏览器的前端编程,但是一位开发者Ryan有一天发现这种前端式的脚本 ...
- Windows环境下Node.js环境搭建
1.Node.js下载与安装 https://nodejs.org/zh-cn/download/ Windows现在windows安装包(.msi),现在后手动安装,安装目录无要求,选项默认即可 2 ...
- 《Node.js入门》CentOS 6.5下Node.js Web开发环境搭建笔记
近期想尝试一下英特尔的基于WebRTC协同通信开发套件,所以须要在本地搭建Node.js Web的开发測试环境. 这里讲的是CentOS 下的搭建方法.使用Windows的小伙伴请參考: <No ...
- 如何从Windows中删除Node.js
如何从Windows中删除Node.js: 1.从卸载程序卸载程序和功能. 2.重新启动(或者您可能会从任务管理器中杀死所有与节点相关的进程). 3.寻找这些文件夹并删除它们(及其内容)(如果还有). ...
- win 环境下 node.js环境变量
在win 环境下 node.js环境变量有两种情况: (1)开发环境(development):开发环境是程序猿们专门用于开发的服务器,配置可以比较随意, 为了开发调试方便,一般打开全部错误报告. ...
- 1. windows环境安装Node.js
1. 下载 地址: https://nodejs.org/en/ 2. 下载最新版本v6.1.0 Currrent
- <亲测>CentOS 7.3下Node.js 8.6安装配置(含NPM以及PM2)
CentOS 7.3下Node.js 8.6安装配置 2017年09月30日 14:12:02 阅读数:2245更多 个人分类: Nodejs 版权声明:本文为博主原创文章,未经博主允许不得转载. ...
- VUE npm run dev 启动时,报了一大堆错误 Node Sass could not find a binding for your current environment: Windows 64-bit with Node.js 7.x
npm run dev 启动时,报了一大堆错误 Module build failed: Error: Missing binding E:\2017VocaSchool\vocationWeb\no ...
随机推荐
- php获取指定目录下的所有文件列表
在我们实际的开发需求中,经常用到操作文件,今天就讲一下关于获取指定目录下的所有文件的几种常用方法: 1.scandir()函数 scandir() 函数返回指定目录中的文件和目录的数组. scandi ...
- Mysql-单表查询的操作和注意事项
一. 单表查询的语法 二 .关键字的执行优先级(重点) 三 .简单查询 四 .WHERE约束 五. 分组查询:GROUP BY 六 .HAVING过滤 七 .查询排序:ORDER BY 八 .限制查询 ...
- arcEngine开发之查询的相关接口
属性查询 IQueryDef 首先这个接口不能直接创建,可以由 IFeatureWorkspace 接口的CreateQueryDef创建. 这个接口有两个属性必须设置(帮助文档是这样说明的,但是实际 ...
- java ArrayList集合
ArrayList集合是程序中最常见的一种集合,它属于引用数据类型(类).在ArrayList内部封装了一个长度可变的数组,当存入的元素超过数组长度时,ArrayList会在内存中分配一个更大的数组来 ...
- HTTP和SOAP完全就是两个不同的协议
HTTP只负责把数据传送过去,不会管这个数据是XML.HTML.图片.文本文件或者别的什么.而SOAP协议则定义了怎么把一个对象变成XML文本,在远程如何调用等,怎么能够混为一谈. ...
- springmvc配置详解 教程
https://www.cnblogs.com/sunniest/p/4555801.html
- tkinter中鼠标与键盘事件(十五)
鼠标与键盘事件 import tkinter wuya = tkinter.Tk() wuya.title("wuya") wuya.geometry("300x200+ ...
- 玩转CSS3(一)----CSS3实现页面布局
请珍惜小编劳动成果,该文章为小编原创,转载请注明出处. 摘要: CSS3相对CSS2增加了一些新的布局方式:多栏布局和盒子布局.在这篇文章中,将对CSS2的布局进行简单的回忆,并总结CSS3的 ...
- attr和prop的区别以及在企业开发中应该如何抉择
attr和prop有很多相同的地方,比如都可以操作标签的属性节点,而且获取的时候都只可以获取到相同节点的第一个,例如这样: $('span').attr('class');和$('span').pro ...
- netData.go 阅读源码
) // 定义数据传输结构 type NetData struct { // 消息体 Body interface{} // 操作代号 Operation string ...