当前位置: 首页 > news >正文

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

导入pdf-lib库和fontkit

npm install pdf-lib fs
npm install @pdf-lib/fontkit

具体代码

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进行制作,百度一下都能查到

http://www.lryc.cn/news/141776.html

相关文章:

  • UE4与pycharm联合仿真的调试问题及一些仿真经验
  • 【数据分析】波士顿矩阵
  • sizeof和strlen的对比
  • Flutter系列文章-Flutter 插件开发
  • 基于SpringBoot实现MySQL与Redis的数据最终一致性
  • mysql与oracle数据库备份
  • UE4 材质学习笔记
  • TiDB 源码编译之 TiProxy 篇
  • 利用驱动漏洞
  • 开始MySQL之路——MySQL约束概述详解
  • CMake基础和命令介绍
  • 【matlab利用shp文件制作mask白化文件】
  • 【LLM】解析pdf文档生成摘要
  • 方案:AI边缘计算智慧工地解决方案
  • 【Python】【数据结构和算法】查找最大或最小的N个元素
  • C++day1(笔记整理)
  • 关于chromedriver.exe一系列问题的解决办法
  • css-选择器、常见样式、标签分类
  • 三星申请新商标:未来将应用于智能戒指,作为XR头显延伸设备
  • 0201hdfs集群部署-hadoop-大数据学习
  • DevOps中的持续测试优势和工具
  • 函数-C语言(初阶)
  • elementuiplus设置scroll-to-error之后 提示被遮挡的解决方案
  • vue中将新添加的div标签自动定位到可视区域内
  • Vue3笔记——(尚硅谷张天禹Vue笔记)
  • 正则表达式一小时学完
  • 上门服务系统|上门服务小程序如何提升生活质量?
  • 系统报错msvcp120.dll丢失的解决方法,常见的三种解决方法
  • 数据库备份工具有哪些
  • Sentinel流量控制与熔断降级