node.js提取excel中的信息填充到word文件,批量生成合同

1.npm下载

复制代码
npm i pizzip docxtemplater xlsx

2.excel模板

3.word模板

4.代码

复制代码
// 引入所需模块
var PizZip = require('pizzip');
var Docxtemplater = require('docxtemplater');
var fs = require('fs');
var path = require('path');
var xl = require('xlsx');

// 读取并导出Excel文件 ./en.xlsx
var workbook = xl.readFile("./en.xlsx")
const sheetNames = workbook.SheetNames; // 返回 ['sheet1', 'sheet2']

// 根据表名获取对应某张表
const worksheet = workbook.Sheets[sheetNames[0]]; // 获取第一张表
var dataa = xl.utils.sheet_to_json(worksheet); // 将表转换为JSON对象数组
// console.log(dataa);

// 处理数据,创建一个新数组,其中包含具有中文名、中文描述和英文描述的对象
let distdata = []
for (let i = 0; i < dataa.length; i++) {
  const element = dataa[i];
  let obj = {
    name: element.__EMPTY,// 获取中文名
    chinese: element.__EMPTY_1,// 获取中文描述
    english: element.__EMPTY_2 // 获取英文描述
  }
  distdata.push(obj)
}

// console.log(distdata)
// 读取word文件,以二进制文件形式保存
var content = fs.readFileSync(path.resolve(__dirname, './a1.docx'), 'binary'); // 读取word文件
// 遍历处理后的数据,为每个对象生成一个word文件
for (let i = 0; i < distdata.length; i++) {
  // 创建一个新的PizZip对象
  var zip = new PizZip(content);
  var doc = new Docxtemplater(zip);
  // 获取当前遍历的对象
  let ele = distdata[i]
  // 设置填充数据
  doc.setData(
    {
      name: ele.name,
      chinese: ele.chinese,
      english: ele.english
    }
  );
  //渲染数据生成文档
  doc.render()
  // 将文档转换文nodejs能使用的buf
  var buf = doc.getZip().generate({ type: 'nodebuffer' });
  // 导出文档名字/类型
  fs.writeFileSync(path.resolve(__dirname, `./word/${distdata[i].name}.docx`), buf);
}

5.运行结果 node ./app.js

6.全部内容 zip 包 看资源绑定

相关推荐
之恒君11 小时前
Node.js 模块加载 - 4 - CJS 和 ESM 互操作避坑清单
前端·node.js
Esun_R15 小时前
当 LLM 开始连接真实世界:MCP 的原理、通信与工程落地
node.js·openai·mcp
爱写程序的小高17 小时前
npm ERR! code ERESOLVE npm ERR! ERESOLVE unable to resolve dependency tree
前端·npm·node.js
程序员爱钓鱼17 小时前
Node.js 编程实战:测试与调试 - 单元测试与集成测试
前端·后端·node.js
哟哟耶耶18 小时前
Plugin-webpack内置功能split-chunks-plugin配置打包代码分割
前端·webpack·node.js
SailingCoder19 小时前
AI 流式对话该怎么做?SSE、fetch、axios 一次讲清楚
前端·javascript·人工智能·ai·node.js
天远数科20 小时前
Node.js全栈实战:基于天远名下车辆数量查询API实现的智能资产核验组件
大数据·node.js
嫂子的姐夫20 小时前
013-webpack:新东方
爬虫·python·webpack·node.js·逆向
爱写程序的小高21 小时前
npm版本降级、nvm切换node版本、webpack版本与vue版本不一致
前端·npm·node.js
嚣张丶小麦兜21 小时前
npm的应用
前端·npm·node.js