「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > Node.js で PDF ページを画像に変換する方法

Node.js で PDF ページを画像に変換する方法

2024 年 11 月 7 日に公開
ブラウズ:913

How to Convert PDF Pages to Images in Node.js

この記事では、Node.js を使用して PDF ページを画像に変換する方法について説明します。これは、サムネイルを生成したり、PDF ファイルからビジュアル コンテンツを抽出したりする場合に役立ちます。 pdfjs-dist ライブラリを使用して PDF ページをロードおよびレンダリングし、canvas を使用して画像バッファを作成します。

前提条件
始める前に、必要なパッケージをインストールする必要があります:

npm インストール pdfjs-dist キャンバス

PDF ページを画像に変換してローカルに保存するコード:

const fs = require('fs');
const path = require('path');
const pdfjs = require('pdfjs-dist/legacy/build/pdf.js');
const Canvas = require('canvas');

/**
 * Converts a PDF to images by rendering each page and saving them to a local directory.
 * 
 * @param {Buffer} pdfBuffer - The PDF file as a buffer.
 * @param {string} outputDir - The directory where images will be saved.
 * @returns {Promise} Resolves when all images are saved.
 */
async function convertPdfToImages(pdfBuffer, outputDir) {
  try {
    // Ensure the output directory exists
    if (!fs.existsSync(outputDir)) {
      fs.mkdirSync(outputDir, { recursive: true });
    }

    // Load the original PDF using pdf.js
    const loadingTask = pdfjs.getDocument({ data: pdfBuffer });
    const pdfDocument = await loadingTask.promise;

    // Loop through each page of the PDF
    for (let i = 1; i } The image as a buffer (JPEG format).
 */
async function renderPageToImage(page) {
  // Scale the page to 2x for a higher quality image output
  const viewport = page.getViewport({ scale: 2.0 });
  const canvas = Canvas.createCanvas(viewport.width, viewport.height);
  const context = canvas.getContext('2d');

  const renderContext = {
    canvasContext: context,
    viewport: viewport,
  };

  // Render the PDF page to the canvas
  await page.render(renderContext).promise;

  // Convert the canvas content to a JPEG image buffer and return it
  return canvas.toBuffer('image/jpeg');
}

// Example usage:
// const pdfBuffer = fs.readFileSync('sample.pdf');
// convertPdfToImages(pdfBuffer, './output_images');

コードの説明

  1. PDF のロード: pdfjs-dist を使用して、バッファから PDF ファイルをロードします。
const loadingTask = pdfjs.getDocument({ data: pdfBuffer });
const pdfDocument = await loadingTask.promise;
  1. 各ページのレンダリング: PDF 内の各ページについて、getPage を使用してキャンバス上にレンダリングし、pdfjs-dist のレンダリング メソッドを実行します。
const page = await pdfDocument.getPage(pageNumber);
const renderContext = {
  canvasContext: context,
  viewport: viewport,
};
await page.render(renderContext).promise;
  1. 画像をローカルに保存: ページがキャンバスにレンダリングされたら、Node.js の fs モジュールを使用して画像バッファーを JPEG 形式で保存します。
fs.writeFileSync(imagePath, imageBuffer);

結論:
このアプローチは PDF を画像に変換する場合に効率的に機能し、PDF コンテンツを処理または視覚化できるようになります。高品質の画像の場合、キャンバスを 2 倍に拡大縮小します。これは、ニーズに基づいて簡単に調整できます。

これがお役に立てば幸いです!要件に応じてコードを自由に調整してください。

リリースステートメント この記事は次の場所に転載されています: https://dev.to/yashnarkhedkar/how-to-convert-pdf-pages-to-images-in-nodejs-2a6k?1 侵害がある場合は、[email protected] までご連絡ください。それを削除するには
最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3