nodejs根据pdf模板填入中文数据并生成新的pdf文件

导入pdf-lib库和fontkit

javascript 复制代码
npm install pdf-lib fs
npm install @pdf-lib/fontkit

具体代码

javascript 复制代码
const { PDFDocument, StandardFonts } = require('pdf-lib');
const fs = require('fs');
const fontkit = require('@pdf-lib/fontkit')
let pdfDoc
let font
async function fillPdfForm(templatePath, outputPath, data) {
  const templateBytes = await fs.promises.readFile(templatePath);
  const fontBytes = await fs.promises.readFile('xxx.ttf');
  pdfDoc = await PDFDocument.load(templateBytes);
  pdfDoc.registerFontkit(fontkit);
  font = await pdfDoc.embedFont(fontBytes);
  const form = pdfDoc.getForm();

  for (const fieldKey in data) {
    const field = form.getTextField(fieldKey);
    if (field) {
      field.setText(data[fieldKey]);
      field.updateAppearances(font)
    }
  }

  const modifiedPdfBytes = await pdfDoc.save();

  await fs.promises.writeFile(outputPath, modifiedPdfBytes);
}

// 使用示例
const templatePath = 'template.pdf';
const outputPath = 'output.pdf';
const data = {
  'key': 'value支持中文参数',
};

fillPdfForm(templatePath, outputPath, data)
  .then(() => {
    console.log('PDF生成成功');
  })
  .catch((error) => {
    console.log('PDF生成失败:', error);
  });

代码详解

首先

const templateBytes = await fs.promises.readFile(templatePath);

const pdfDoc = await PDFDocument.load(templateBytes);

const form = pdfDoc.getForm();

这三行表示读文件,并且读取pdf表单,然后注册fontkit,将你要的字体嵌入pdf中,之后在pdf的表单中寻找字段,填入字段,并把字体样式更新为你嵌入pdf的字体

这里的Object.entries是将对象变成数组方便循环,也可以用for...in进行对象遍历

最后将数据存入新文件中

注意

这里的字体文件只支持ttf和otf不支持电脑C盘里的那些的ttc

其他

pdf模板可以使用福昕pdf进行制作,百度一下都能查到

相关推荐
2501_94471143几秒前
JS 对象遍历全解析
开发语言·前端·javascript
凡人叶枫26 分钟前
C++中智能指针详解(Linux实战版)| 彻底解决内存泄漏,新手也能吃透
java·linux·c语言·开发语言·c++·嵌入式开发
Tony Bai26 分钟前
再见,丑陋的 container/heap!Go 泛型堆 heap/v2 提案解析
开发语言·后端·golang
发现一只大呆瓜34 分钟前
虚拟列表:支持“向上加载”的历史消息(Vue 3 & React 双版本)
前端·javascript·面试
小糯米6011 小时前
C++顺序表和vector
开发语言·c++·算法
froginwe111 小时前
JavaScript 函数调用
开发语言
阔皮大师1 小时前
INote轻量文本编辑器
java·javascript·python·c#
lbb 小魔仙1 小时前
【HarmonyOS实战】React Native 表单实战:自定义 useReactHookForm 高性能验证
javascript·react native·react.js
独望漫天星辰1 小时前
C++ 多态深度解析:从语法规则到底层实现(附实战验证代码)
开发语言·c++
_codemonster1 小时前
Vue的三种使用方式对比
前端·javascript·vue.js