Node.Js 实现模板生成Word、Word转Pdf文件、Excel生成、上传和下载

第三方插件依赖

复制代码
const XLSX = require('xlsx');
const Docxtemplater = require("docxtemplater"); // 引入Docxtemplater模块
const Enumerable = require('linq');
const fs = require('fs');
const PizZip = require("jszip"); // 引入PizZip=>jszip模块


function genFile(templatePath,outPath,data){
  if (!fs.existsSync(templatePath)) {
    fs.mkdirSync(templatePath, { recursive: true });
    // throw new Error("File not found");return;
  }
  var content = fs.readFileSync(templatePath, "binary");
  // 解压文件的内容
  const zip = new PizZip(content); // 创建一个新的PizZip实例
  // 解析模板,并在模板无效时抛出错误,例如,如果模板是"{user"(没有闭合标签)
  const doc = new Docxtemplater(zip, { // 创建Docxtemplater实例
      paragraphLoop: true, // 允许段落循环
      linebreaks: true, // 保持换行符
  });
  
  doc.render(data);
  // 获取zip文档并将其生成为Node.js缓冲区
  const buf = doc.getZip().generate({ // 生成文档的zip格式
      type: "nodebuffer", // 生成类型为nodebuffer
      compression: "DEFLATE", // 压缩类型为DEFLATE
  });
  fs.writeFileSync(outPath, buf); // 将渲染后的文档写入到downName.docx文件
}

模板文件参照

生成文件

excel文件如下

复制代码
//移除不需要导出的列
      for(var obj of newQualityData){
        delete obj.deviceType;
        delete obj.qualityType;
        delete obj.sStation;
        delete obj.taskType;
      }
      const ws = XLSX.utils.json_to_sheet(newQualityData);
      var time=moment().format('x');//返回字符串型毫秒时间戳   (req.body.time).format("YYYYMMDDHHmmss")
      // 创建一个新的工作簿并添加工作表
      const wb = XLSX.utils.book_new();
      XLSX.utils.book_append_sheet(wb, ws, "Sheet1");
      // 写入文件
      // console.log(path.resolve(__dirname, '..'));//根目录
      // console.log(path.resolve(__dirname, '../'));//上一级目录
      var savePath=path.join(path.resolve(__dirname, '../')+"/download_file",`${time}.xlsx`);
      XLSX.writeFile(wb, savePath);
      res.send({code:200,res:true,str:`${time}.xlsx`});

上传和下载

复制代码
//上传
router.all('/Common/Upload',async(req,res,next)=>{
  try{
    let ret_files=[];
    if (req.files){
      const allowedMimes = [
        'image/jpeg',
        'image/png',
        'image/gif',
        'image/webp',
        'application/pdf',
        'text/plain',
        'application/msword',
        'application/vnd.openxmlformats-officedocument.wordprocessingml.document'
      ];// 允许的文件类型
      let files;
      files=req.files;
      for(let file of files){
        if (!allowedMimes.includes(file.mimetype)) {
          res.send({code:500,rc:false,str:'不支持的文件格式!'});
        } 
        let file_ext=file.originalname.substring(file.originalname.lastIndexOf('.')+1);//文件后缀
        let file_name=moment().format('x')+"."+file_ext;//时间戳作为文件名称
        fs.renameSync(process.cwd()+"/download_file/upload/temp/"+file.filename,process.cwd()+"/download_file/upload/"+file_name);//移动文件兵修改文件名称
        ret_files.push({name:file_name,url:'/download_file/upload/'+file_name})
      }
    }
    res.send({code:200,rc:true,ret_files});
  }
  catch(error){
    console.log(error);
    res.send({ code:500,rc: false,str: error.message});
  }
  finally{
      
  }

});

//下载
router.all('/Common/Download',async(req,res,next)=>{
  try{
    res.download(process.cwd()+req.body.file_url);
  }
  catch(error){
    console.log(error);
    res.send({ code:500,rc: false,str: error.message});
  }
  finally{
      
  }

});
相关推荐
donecoding35 分钟前
Corepack 完全解析:从懵到懂,包管理器自由了
前端·node.js·前端工程化
PaperData2 小时前
2000-2025年《中国县域统计年鉴》pdf+excel版(附赠面板数据)
数据库·人工智能·数据分析·pdf·经管
weixin_416660072 小时前
豆包公式转Word,乱码解决
word·latex·豆包
狐狐生风3 小时前
LangChain实现简易版-----PDF 文档问答机器人
人工智能·langchain·机器人·pdf·prompt
王莎莎-MinerU4 小时前
从 PDF 到知识资产:MinerU 文档解析如何成为企业 RAG 系统的“数据基石”
大数据·人工智能·pdf·个人开发
molihuan5 小时前
最新 将 MuPDF 编译到 Android 动态库 PDF解析渲染引擎
android·pdf
donecoding17 小时前
一个 sudo 引发的血案:npm 全局包权限错乱彻底修复
前端·node.js·前端工程化
Muyuan199820 小时前
27.RAG 系统中的上下文充分性判断:从 Chunk 数量、FAISS 距离到 LLM Relevance Gate
python·django·pdf·fastapi·faiss
开开心心就好1 天前
近200个工具的电脑故障修复合集
安全·智能手机·pdf·电脑·consul·memcache·1024程序员节
donecoding1 天前
别再让 pnpm 跟着 nvm 跑了!独立安装终极指南
前端·node.js·前端工程化