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

Mary-Kate Olsen
Lepaskan: 2024-10-22 07:52:02
asal
779 orang telah melayarinya

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>
Salin selepas log masuk

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>
Salin selepas log masuk

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!

sumber:php
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan