百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

5种开源PDF解析方案(JS/Node.js)及实战教程

liuian 2025-05-28 18:47 71 浏览

hi, 大家好, 我是徐小夕.

徐小夕【知乎专栏作家】掘金签约作者,定期分享AI创业,可视化,企业实战项目知识,深度复盘企业中经常遇到的500+技术问题解决方案。【关注趣谈前端,技术路上不迷茫】

最近一直在迭代 flowmix/docx 多模态文档编辑器,其中涉及到文件解析相关的功能实现,比如PDF解析,Docx解析,接下来我就和大家分享5种解析PDF文件的方案,并提供不同方案的对比技术选型分析,帮助大家更好的实现web端文档解析能力。

5种开源PDF解析方案(JS/Node.js)及实战教程

PDF作为最常见的文档格式之一,解析其内容(如文本、表格、图片)是开发者常遇到的挑战。本文将介绍 5种开源的JavaScript/Node.js方案,并提供从安装到实战的完整教程,助大家快速选择适合的工具!


一、pdf.js(Mozilla官方出品)

Mozilla开发的PDF渲染与解析库,支持浏览器和Node.js环境,适合提取文本和渲染页面。

安装:

npm install pdfjs-dist

基础用法:

const pdfjsLib = require('pdfjs-dist');


async function parsePDF(filePath) {
  const loadingTask = pdfjsLib.getDocument(filePath);
  const pdf = await loadingTask.promise;


  for (let pageNum = 1; pageNum <= pdf.numPages; pageNum++) {
    const page = await pdf.getPage(pageNum);
    const content = await page.getTextContent();
    const text = content.items.map(item => item.str).join(' ');
    console.log(`第${pageNum}页文本:`, text);
  }
}


parsePDF('example.pdf');

应用场景:

  • 网页端PDF预览
  • 高精度文本提取(支持复杂布局)


二、pdf-parse(轻量级文本提取)

基于pdf.js的封装库,简化文本提取流程,适合快速获取纯文本内容。

安装:

npm install pdf-parse

基础使用:

const fs = require('fs');
const pdfParse = require('pdf-parse');


async function extractText() {
  const dataBuffer = fs.readFileSync('example.pdf');
  const { text } = await pdfParse(dataBuffer);
  console.log('PDF全文:', text);
}


extractText();

应用场景:

  • 快速提取纯文本(如日志分析)
  • 无需处理复杂格式的场景


三、pdf-lib(编辑与创建PDF)

支持PDF编辑、表单填写、合并/拆分文件,功能强大但文本提取较弱。

基本使用介绍:

const { PDFDocument } = require('pdf-lib');
const fs = require('fs');


async function editPDF() {
  const pdfBytes = fs.readFileSync('example.pdf');
  const pdfDoc = await PDFDocument.load(pdfBytes);


  const page = pdfDoc.getPage(0);
  page.drawText('Hello PDF-Lib!', { x: 50, y: 500 });


  const modifiedPdf = await pdfDoc.save();
  fs.writeFileSync('modified.pdf', modifiedPdf);
}


editPDF();

应用场景:

  • 动态生成PDF(如报告、合同)
  • 修改现有PDF内容


四、pdf2json(结构化数据提取)

将PDF转换为JSON格式,保留文本位置、字体等元数据。

基本使用方法:

const fs = require('fs');
const PDFParser = require('pdf2json');


const pdfParser = new PDFParser();
pdfParser.on('pdfParser_dataReady', (data) => {
  fs.writeFileSync('output.json', JSON.stringify(data));
});


pdfParser.loadPDF('example.pdf');

应用场景:

  • 需要分析文本位置(如表格识别)
  • 数据挖掘与结构化处理

五、node-hummus(底层操作PDF)

基于C++的PDF处理库,适合高性能场景,但学习曲线较高。

基本使用:

const hummus = require('hummus');


function mergePDFs() {
  const pdfWriter = hummus.createWriter('merged.pdf');
  const firstPDF = new hummus.PDFRStreamForFile('file1.pdf');
  pdfWriter.appendPDFPagesFromPDF(firstPDF);
  const secondPDF = new hummus.PDFRStreamForFile('file2.pdf');
  pdfWriter.appendPDFPagesFromPDF(secondPDF);
  pdfWriter.end();
}


mergePDFs();

应用场景:

  • 高性能PDF合并/拆分
  • 添加水印或页眉页脚

方案对比与选型建议

选型建议:

  • 仅需提取文本 → pdf-parse
  • 需渲染PDF页面 → pdf.js
  • 编辑/生成PDF → pdf-lib
  • 高性能处理 → node-hummus(需注意维护状态)

Flowmix/docx多模态文档编辑器介绍

Flowmix/docx 是一款开箱即用的多模态文档解决方案,我们可以在Flowmix/docx中编写多模态的内容, 如音视频, 思维导图,可视化图表, 原型白板, 业务信息卡片等, 几乎所有浏览器支持的组件形态, 都能低成本封装成Flowmix/docx的文档组件. 从而帮助企业构建更加强大文档知识管理系统.

目前Flowmix/docx已支持ReactVue版本, 底层采用插件化设计, 企业研发人员可以低成本集成到内部产品或系统.

我们可以使用它来实现类似腾讯文档, 飞书文档, ones等项目管理平台, 下面是我们基于flowmix/docx 实现的一个轻文档平台的编辑器界面, 大家可以参考一下:

后续规划

最近我们做了一款文档管理类Saas系统, 底层基于Flowmix/Docx 多模态文档引擎, 这里简单和大家分享一下:

大家可以使用它来管理自己的内容知识文档, 同时能一键生成自己的专属知识库.

文档地址: https://orange.turntip.cn/doc

如果大家有好的想法,欢迎随时在留言区交流反馈~



相关推荐

路由器恢复出厂设置会怎么样

现在的很多路由器都很智能化,我们在日常使用的时候,很多时候出现卡死或者忘记了路由器的登录密码等问题,这个时候我们就需要对路由器进行重置或者是恢复出厂设置,这样就可以用初始化的用户名和密码登录路由器了...

电脑密码忘了如何取消开机密码

1/5第一种方法:在开机时,按下F8进入带命令提示符的安全"模式输入"netuser+用户名+123456/add"可把自己的密码设置为"123456",这样进入控制面板就可以清除自己用户密码了。...

安卓手机exe文件怎么打开(安卓手机用什么打开exe文件)

在Android操作系统中,通常情况下是无法直接运行.exe文件的,因为Android手机和Windows操作系统在底层架构上存在较大差异。不过,有一些方法可以让Android手机...

声卡怎么安装在电脑主机上(声卡怎么插到电脑上)

安装电脑主机的声卡通常需要进行以下步骤:1.确认声卡的类型:首先,确定您要安装的声卡类型,是内置声卡还是外部插卡声卡。内置声卡通常已经集成在主板上,而外部插卡声卡需要插入主板的PCIe插槽或其他的扩...

hplaserjet1020驱动下载 win10

您好,感谢您选择惠普产品。首先确认打印机本身无报错请您点击开始--设置--打印机和传真(设备和打印机)--看到打印机图标把鼠标放在图标上确认状态文档是否为就绪文档0如果不是建议删除文档重启电脑,...

联想小新怎么找售后维修(联想小新怎么找售后维修点)

给大家介绍几种解决的办法,大家可以试试:方法一:最简单的方法就是重启一下你的电脑,一般没有太大问题重启一下电脑就可以了。方法二:如果你电脑中安装了360安全卫士,那么你可以打开360安全卫士,然后点击...

笔记本win10系统重装(笔记本win10系统重装u盘启动)

win10系统重装方法如下第一步:下载安装好老毛桃U盘启动盘制作工具,制作一个U盘启动盘,建议U盘内存在8G以打开浏览器,搜索“老毛桃官网”,进入官网后,在首页点击“完整版”下载第二步:下载好win1...

主题之家移动版(主题中心下载手机版)

根据我的了解,汽车之家王国分为多个主题。其中包括新车评测、汽车导购、行业资讯、改装技术、赛车运动等。新车评测主题提供各种品牌和型号的汽车评测文章和视频,帮助消费者了解车辆性能和特点。汽车导购主题提供购...

win7电脑分盘(windows7电脑分盘)

在Win7系统电脑上分盘,您可以按照以下步骤进行操作:1.打开“计算机管理”:右键点击“计算机”图标,选择“管理”选项,打开“计算机管理”窗口。2.打开“磁盘管理”:在“计算机管理”窗口中,选择“...

电脑任务栏怎么还原到下边快捷键

电脑任务栏还原到下边方法:1.在任务栏上单击右键进入Windows电脑桌面后直接在任务栏上单击鼠标右键。2.点击锁定任务栏在弹出的菜单里面点击倒数第二个锁定任务栏选项。3.将任务栏拖到下方再按下鼠标左...

windows7怎么单击修复计算机

方法/步骤windows7的设置一般都可以在“控制面板”调整,鼠标的功能调整也不例外。首先打开“开始”-“控制面板”。“控制面板”默认是按照类别分类的,可能看不到鼠标选项,不过我们可以在搜索框里搜索“...

rog售后维修服务中心(rog官方维修点查询)

如果你的rog手机坏了,可以选择去rog手机官方维修点或者授权的维修中心修理。在这些地方,工程师们具有专业的维修知识和技能,能够确保对rog手机进行正确的维修和保养。此外,他们也会使用原厂备件,以确保...

装机系统哪个好(装系统那个好)

一、【重装win10正版系统】   二、【好用一键重装系统】  三、【优盘一键重装系统】 四、【免u盘一键重装系统】五、【小白在线一键重装系...

计算机怎么设置密码(计算机怎么设置密码锁屏)
  • 计算机怎么设置密码(计算机怎么设置密码锁屏)
  • 计算机怎么设置密码(计算机怎么设置密码锁屏)
  • 计算机怎么设置密码(计算机怎么设置密码锁屏)
  • 计算机怎么设置密码(计算机怎么设置密码锁屏)
win10刻录光盘的方法和步骤(win10系统怎么刻录光盘)

1.打开Windows10中的“文件资源管理器”,找到要刻录的文件或文件夹。2.选中文件/文件夹,右键单击选中“发送到-->DVDRW驱动器”。3.确认要刻录的光盘的名称和格式(默...