自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

五種開源PDF解析方案(JS/Node.js)及實戰(zhàn)教程

開發(fā) 前端
PDF作為最常見的文檔格式之一,解析其內(nèi)容(如文本、表格、圖片)是開發(fā)者常遇到的挑戰(zhàn)。本文將介紹 5種開源的JavaScript/Node.js方案,并提供從安裝到實戰(zhàn)的完整教程,助大家快速選擇適合的工具!

最近一直在迭代 flowmix/docx 多模態(tài)文檔編輯器,其中涉及到文件解析相關(guān)的功能實現(xiàn),比如PDF解析,Docx解析,接下來我就和大家分享5種解析PDF文件的方案,并提供不同方案的對比和技術(shù)選型分析,幫助大家更好的實現(xiàn)web端文檔解析能力。

圖片圖片

5種開源PDF解析方案(JS/Node.js)及實戰(zhàn)教程

PDF作為最常見的文檔格式之一,解析其內(nèi)容(如文本、表格、圖片)是開發(fā)者常遇到的挑戰(zhàn)。本文將介紹 5種開源的JavaScript/Node.js方案,并提供從安裝到實戰(zhàn)的完整教程,助大家快速選擇適合的工具!

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

圖片圖片

Mozilla開發(fā)的PDF渲染與解析庫,支持瀏覽器和Node.js環(huán)境,適合提取文本和渲染頁面。

安裝:

npm install pdfjs-dist

基礎(chǔ)用法:

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');

應(yīng)用場景:

  • 網(wǎng)頁端PDF預(yù)覽
  • 高精度文本提?。ㄖС謴?fù)雜布局)

二、pdf-parse(輕量級文本提取)

圖片圖片

基于pdf.js的封裝庫,簡化文本提取流程,適合快速獲取純文本內(nèi)容。

安裝:

npm install pdf-parse

基礎(chǔ)使用:

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();

應(yīng)用場景:

  • 快速提取純文本(如日志分析)
  • 無需處理復(fù)雜格式的場景

三、pdf-lib(編輯與創(chuàng)建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();

應(yīng)用場景:

  • 動態(tài)生成PDF(如報告、合同)
  • 修改現(xiàn)有PDF內(nèi)容

四、pdf2json(結(jié)構(gòu)化數(shù)據(jù)提取)

圖片

將PDF轉(zhuǎn)換為JSON格式,保留文本位置、字體等元數(shù)據(jù)。

基本使用方法:

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');

應(yīng)用場景:

  • 需要分析文本位置(如表格識別)
  • 數(shù)據(jù)挖掘與結(jié)構(gòu)化處理

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

圖片

基于C++的PDF處理庫,適合高性能場景,但學(xué)習(xí)曲線較高。

基本使用:

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();

應(yīng)用場景:

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

方案對比與選型建議

圖片

選型建議:

  • 僅需提取文本 → pdf-parse
  • 需渲染PDF頁面 → pdf.js
  • 編輯/生成PDF → pdf-lib
  • 高性能處理 → node-hummus(需注意維護狀態(tài))

Flowmix/docx多模態(tài)文檔編輯器介紹

圖片

Flowmix/docx 是一款開箱即用的多模態(tài)文檔解決方案,我們可以在Flowmix/docx中編寫多模態(tài)的內(nèi)容, 如音視頻思維導(dǎo)圖,可視化圖表原型白板業(yè)務(wù)信息卡片等, 幾乎所有瀏覽器支持的組件形態(tài), 都能低成本封裝成Flowmix/docx的文檔組件. 從而幫助企業(yè)構(gòu)建更加強大文檔知識管理系統(tǒng).

目前Flowmix/docx已支持ReactVue版本,  底層采用插件化設(shè)計, 企業(yè)研發(fā)人員可以低成本集成到內(nèi)部產(chǎn)品或系統(tǒng).

我們可以使用它來實現(xiàn)類似騰訊文檔飛書文檔ones等項目管理平臺, 下面是我們基于flowmix/docx 實現(xiàn)的一個輕文檔平臺的編輯器界面, 大家可以參考一下:

圖片

后續(xù)規(guī)劃

最近我們做了一款文檔管理類Saas系統(tǒng), 底層基于Flowmix/Docx 多模態(tài)文檔引擎, 這里簡單和大家分享一下:

圖片

大家可以使用它來管理自己的內(nèi)容知識文檔, 同時能一鍵生成自己的專屬知識庫.  體驗地址: https://orange.turntip.cn/doc

責(zé)任編輯:武曉燕 來源: 趣談前端
點贊
收藏

51CTO技術(shù)棧公眾號