最近在做了一个小程序!里面有个功能就是根据用户提交的数据,自动生成一份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文件的更多相关文章

  1. Windows 7 下 Node.js 连接 Oracle

    原创作者: sailtseng 1. 安装 Oracle 11g express  详见: <Windows 7 x64 安装 Oracle 11g Express> 2. 安装 Micr ...

  2. Windows 7下Node.js Web开发环境搭建笔记

    Node.js是什么? 我们看看百科里怎么说的?JavaScript是一种运行在浏览器的脚本,它简单,轻巧,易于编辑,这种脚本通常用于浏览器的前端编程,但是一位开发者Ryan有一天发现这种前端式的脚本 ...

  3. Windows环境下Node.js环境搭建

    1.Node.js下载与安装 https://nodejs.org/zh-cn/download/ Windows现在windows安装包(.msi),现在后手动安装,安装目录无要求,选项默认即可 2 ...

  4. 《Node.js入门》CentOS 6.5下Node.js Web开发环境搭建笔记

    近期想尝试一下英特尔的基于WebRTC协同通信开发套件,所以须要在本地搭建Node.js Web的开发測试环境. 这里讲的是CentOS 下的搭建方法.使用Windows的小伙伴请參考: <No ...

  5. 如何从Windows中删除Node.js

    如何从Windows中删除Node.js: 1.从卸载程序卸载程序和功能. 2.重新启动(或者您可能会从任务管理器中杀死所有与节点相关的进程). 3.寻找这些文件夹并删除它们(及其内容)(如果还有). ...

  6. win 环境下 node.js环境变量

     在win 环境下 node.js环境变量有两种情况:  (1)开发环境(development):开发环境是程序猿们专门用于开发的服务器,配置可以比较随意, 为了开发调试方便,一般打开全部错误报告. ...

  7. 1. windows环境安装Node.js

    1. 下载 地址: https://nodejs.org/en/ 2. 下载最新版本v6.1.0 Currrent

  8. <亲测>CentOS 7.3下Node.js 8.6安装配置(含NPM以及PM2)

    CentOS 7.3下Node.js 8.6安装配置 2017年09月30日 14:12:02 阅读数:2245更多 个人分类: Nodejs   版权声明:本文为博主原创文章,未经博主允许不得转载. ...

  9. 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 ...

随机推荐

  1. kaggle入门项目:Titanic存亡预测(三)数据可视化与统计分析

    ---恢复内容开始--- 原kaggle比赛地址:https://www.kaggle.com/c/titanic 原kernel地址:A Data Science Framework: To Ach ...

  2. hive------ Group by、join、distinct等实现原理

    1. Hive 的 distribute by Order by 能够预期产生完全排序的结果,但是它是通过只用一个reduce来做到这点的.所以对于大规模的数据集它的效率非常低.在很多情况下,并不需要 ...

  3. 从一个微型例子看“C/C++的内存分配机制”和“数组变量名与指针变量名”(转)

    C++的内存有五大分区:堆区.栈区.自由存储区.全局/静态存储区.常量存储区. 五个数据段:数据段.代码段.BSS段.堆.栈 内存分配方式有三种: 从静态存储区域分配.内存在程序编译的时候就已经分配好 ...

  4. 单片机开发——02工欲善其事必先利其器(Proteus软件安装破解)

    在单片机开发工程中,博主经常通过模拟软件Proteus进行模拟仿真,将编译生成的"HEX"文件下载在单片机芯片中,然后进行后期的debug工作,当模拟仿真完成之后,进行硬件测试部分 ...

  5. Python_二叉树

    BinaryTree.py '''二叉树:是每个节点最多有两个子树(分别称为左子树和右子树)的树结构,二叉树的第i层最多有2**(i-1)个节点,常用于排序或查找''' class BinaryTre ...

  6. PHP内核之旅-3.变量

    PHP 内核之旅系列 PHP内核之旅-1.生命周期 PHP内核之旅-2.SAPI中的Cli PHP内核之旅-3.变量 一.弱类型语言 php是弱类型语言.一个变量可以表示任意数据类型. php强大的一 ...

  7. Jenkins通过Publish over SSH插件实现远程部署

    Jenkins通过Publish over SSH插件实现远程部署 步凑一.配置ssh免秘钥登录 部署详情地址:http://www.cnblogs.com/Dev0ps/p/8259099.html ...

  8. Java 的字节流文件读取(一)

    上篇文章我们介绍了抽象化磁盘文件的 File 类型,它仅仅用于抽象化描述一个磁盘文件或目录,却不具备访问和修改一个文件内容的能力. Java 的 IO 流就是用于读写文件内容的一种设计,它能完成将磁盘 ...

  9. 配置teredo,启用ipv6,xx-net

    最近使用XX-NET科学上网 ,提示要配置使用IPv6.根据github的上win10配置ipv6方式(https://github.com/XX-net/XX-Net/wiki/IPv6-Win10 ...

  10. linux timerfd系列函数总结

    网上关于timerfd的文章很多,在这儿归纳总结一下方便以后使用,顺便贴出一个timerfd配合epoll使用的简单例子 一.timerfd系列函数 timerfd是Linux为用户程序提供的一个定时 ...