Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Bagaimana untuk Mengekstrak Imej Resolusi Tinggi daripada PDF Tanpa Pensampelan Semula Menggunakan Python?

Bagaimana untuk Mengekstrak Imej Resolusi Tinggi daripada PDF Tanpa Pensampelan Semula Menggunakan Python?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-10-22 07:52:02686semak imbas

How to Extract High-Resolution Images from PDFs Without Resampling Using Python?

Bagaimana untuk Mengekstrak Imej daripada PDF Tanpa Pensampelan Semula dalam Python?

Untuk mengekstrak imej daripada dokumen PDF dengan resolusi dan format asalnya, tanpa pensampelan semula, anda boleh menggunakan modul PyMuPDF. Modul Python ini membolehkan anda memproses fail PDF dan memanipulasi kandungannya dengan cekap. Begini cara anda boleh menggunakan PyMuPDF untuk mengekstrak imej:

<code class="python">import fitz

doc = fitz.open("input.pdf")
for page_num in range(len(doc)):
    for img in doc.getPageImageList(page_num):
        xref = img[0]
        pix = fitz.Pixmap(doc, xref)
        if pix.n < 5:  # Check if it's grayscale or RGB
            pix.writePNG(f"page_{page_num}_img_{xref}.png")
        else:  # Convert CMYK to RGB before saving
            pix1 = fitz.Pixmap(fitz.csRGB, pix)
            pix1.writePNG(f"page_{page_num}_img_{xref}.png")</code>

Dalam kod ini, kami mengulangi halaman dan imej dalam PDF. Pembolehubah 'xref' mewakili pengecam unik imej. Bergantung pada ruang warna imej (RGB atau CMYK), kami sama ada menulis imej PNG secara terus atau menukar CMYK kepada RGB sebelum menyimpannya.

Sebagai alternatif, jika anda menggunakan fitz versi 1.19.6, anda boleh menggunakan kod berikut untuk melaksanakan pengekstrakan dengan bar kemajuan untuk keterlihatan yang lebih baik:

<code class="python">import os
import fitz
from tqdm import tqdm

workdir = "path_to_pdf_folder"

for each_path in os.listdir(workdir):
    if ".pdf" in each_path:
        doc = fitz.Document(os.path.join(workdir, each_path))

        for i in tqdm(range(len(doc)), desc="pages"):
            for img in tqdm(doc.get_page_images(i), desc="page_images"):
                xref = img[0]
                image = doc.extract_image(xref)
                pix = fitz.Pixmap(doc, xref)
                pix.save(os.path.join(workdir, f"{each_path[:-4]}_p{i}-{xref}.png"))</code>

Coretan kod ini akan membolehkan anda mengekstrak imej daripada PDF, mengekalkan resolusi dan format asalnya.

Atas ialah kandungan terperinci Bagaimana untuk Mengekstrak Imej Resolusi Tinggi daripada PDF Tanpa Pensampelan Semula Menggunakan Python?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn