Pruebe en producción sin marcas de agua.
Funciona donde lo necesite.
Obtén 30 días de producto totalmente funcional.
Ténlo en funcionamiento en minutos.
Acceso completo a nuestro equipo de asistencia técnica durante la prueba del producto
Este artículo explorará cómo ver archivos PDF en Python utilizando la biblioteca IronPDF.
IronPDF es una potente biblioteca de Python que permite a los desarrolladores trabajar con archivos PDF de manera programática. Con IronPDF, puede generar, manipular y extraer fácilmente datos de documentos PDF, lo que la convierte en una herramienta versátil para diversas tareas relacionadas con PDF. Tanto si necesita crear PDFs desde cero, modificar PDFs existentes o extraer contenido de PDFs, IronPDF le ofrece un completo conjunto de funciones para simplificar su flujo de trabajo.
Algunas de las características de la biblioteca IronPDF for Python son:
Nota: IronPDF produce un archivo de datos PDF con marca de agua. Para eliminar la marca de agua, necesita licenciar IronPDF. Si desea utilizar una versión con licencia de IronPDF, visite el sitio web de IronPDF para obtener una clave de licencia.
Antes de trabajar con IronPDF en Python, hay algunos requisitos previos:
Instalación de Python: Asegúrese de tener Python instalado en su sistema. IronPDF es compatible con las versiones Python 3.x, así que asegúrese de tener una instalación Python compatible.
:InstallCmd pip install ironpdf
:InstallCmd pip install ironpdf
:InstallCmd pip install tkinter
:InstallCmd pip install tkinter
:InstallCmd pip install pillow
:InstallCmd pip install pillow
Entorno de Desarrollo Integrado (IDE): Usar un IDE para gestionar proyectos en Python puede mejorar significativamente tu experiencia de desarrollo. Ofrece funciones como la finalización de código, la depuración y un flujo de trabajo más ágil. Un IDE popular para el desarrollo de Python es PyCharm. Puedes descargar e instalar PyCharm desde el sitio web de JetBrains (https://www.jetbrains.com/pycharm/).
Después de instalar PyCharm IDE, cree un proyecto PyCharm Python siguiendo los siguientes pasos:
Lanza PyCharm: Abre PyCharm desde el lanzador de aplicaciones de tu sistema o el acceso directo en el escritorio.
Crear un nuevo proyecto: Haz clic en "Crear nuevo proyecto" o abre un proyecto de Python existente.
Cómo Convertir PDF a Texto en Python (Tutorial), Figura 1: PyCharm IDE
PyCharm IDE
Configurar ajustes del proyecto: Proporcione un nombre para su proyecto y elija la ubicación para crear el directorio del proyecto. Seleccione el intérprete de Python para su proyecto. A continuación, haga clic en "Crear".
Crear un nuevo proyecto en Python
Para empezar, importe las bibliotecas necesarias. En este caso, se necesitarán las bibliotecas os
, shutil
, ironpdf
, tkinter
, y PIL
. Las bibliotecas os
y shutil
se utilizan para operaciones de archivos y carpetas, ironpdf
es la biblioteca para trabajar con archivos PDF, tkinter
se utiliza para crear la interfaz gráfica de usuario (GUI), y PIL se utiliza para la manipulación de imágenes.
import os
import shutil
import ironpdf
from tkinter import *
from PIL import Image, ImageTk
py
A continuación, define una función llamada convert_pdf_to_images
. Esta función toma como entrada la ruta del archivo PDF. Dentro de la función, se utiliza la biblioteca IronPDF para cargar el documento PDF desde el archivo. A continuación, se especifica una ruta de carpeta para almacenar los archivos de imagen extraídos. El método pdf.RasterizeToImageFiles
de IronPDF se utiliza para convertir cada página del PDF en un archivo de imagen y guardarlo en la carpeta especificada. Y se utiliza una lista para almacenar las rutas de las imágenes. El ejemplo de código completo es el siguiente:
def convert_pdf_to_images(pdf_file):
pdf = ironpdf.PdfDocument.FromFile(pdf_file)
# Extract all pages to a folder as image files
folder_path = "images"
pdf.RasterizeToImageFiles(os.path.join(folder_path, "*.png"))
# List to store the image paths
image_paths = []
# Get the list of image files in the folder
for filename in os.listdir(folder_path):
if filename.lower().endswith((".png", ".jpg", ".jpeg", ".gif")):
image_paths.append(os.path.join(folder_path, filename))
return image_paths
py
Para extraer texto de documentos PDF, visite esta página de ejemplos de código.
Para limpiar los archivos de imagen extraídos cuando se cierra la ventana de la aplicación, defina una función on_closing
. Dentro de esta función, use el método shutil.rmtree()
para eliminar la carpeta images
completa. A continuación, establezca esta función como el protocolo que se ejecutará cuando se cierre la ventana. El siguiente código ayuda a lograr la tarea:
def on_closing():
# Delete the images in the 'images' folder
shutil.rmtree("images")
window.destroy()
window.protocol("WM_DELETE_WINDOW", on_closing)
py
Ahora, vamos a crear la ventana principal de la interfaz gráfica de usuario (GUI) utilizando el constructor Tk()
configurando el título de la ventana como "Image Viewer" y estableciendo la función on_closing()
como el protocolo para manejar el cierre de la ventana.
window = Tk()
window.title("Image Viewer")
window.protocol("WM_DELETE_WINDOW", on_closing)
py
Para mostrar las imágenes y permitir el desplazamiento, crea un widget Canvas
. El widget Canvas
está configurado para llenar el espacio disponible y expandirse en ambas direcciones utilizando pack(side=LEFT, fill=BOTH, expand=True)
. Además, crea un widget de Scrollbar
y configúralo para controlar el desplazamiento vertical de todas las páginas y el lienzo.
canvas = Canvas(window)
canvas.pack(side=LEFT, fill=BOTH, expand=True)
scrollbar = Scrollbar(window, command=canvas.yview)
scrollbar.pack(side=RIGHT, fill=Y)
canvas.configure(yscrollcommand=scrollbar.set)
canvas.bind("<Configure>", lambda e: canvas.configure(
scrollregion=canvas.bbox("all")))
canvas.bind_all("<MouseWheel>", lambda e: canvas.yview_scroll(
int(-1*(e.delta/120)), "units"))
py
A continuación, crea un widget Frame
dentro del lienzo para sostener las imágenes usando create_window()
para colocar el marco dentro del lienzo. Las coordenadas (0, 0)
y el parámetro anchor='nw'
aseguran que el marco comience en la esquina superior izquierda del lienzo.
frame = Frame(canvas)
canvas.create_window((0, 0), window=frame, anchor="nw")
py
El siguiente paso es llamar a la función convert_pdf_to_images()
con el nombre de la ruta de archivo del archivo PDF de entrada. Esta función extrae las páginas del PDF como imágenes y devuelve una lista de rutas de imagen. Al iterar a través de las rutas de las imágenes y cargar cada imagen usando el método Image.open()
de la biblioteca PIL, se crea un objeto PhotoImage
utilizando ImageTk.PhotoImage()
. Luego crea un widget Label
para mostrar la imagen.
images = convert_pdf_to_images("input.pdf")
# Load and display the images in the Frame
for image_path in images:
image = Image.open(image_path)
photo = ImageTk.PhotoImage(image)
label = Label(frame, image=photo)
label.image = photo # Store a reference to prevent garbage collection
label.pack(pady=10)
py
El archivo de entrada
Finalmente, ejecutemos el bucle de eventos principal usando window.mainloop()
. Esto garantiza que la ventana GUI permanezca abierta y responda hasta que el usuario la cierre.
window.mainloop()
py
La salida de la interfaz de usuario
Este tutorial exploró cómo ver documentos PDF en Python utilizando la biblioteca IronPDF. Cubre los pasos necesarios para abrir un archivo PDF y convertirlo en una serie de archivos de imagen, y luego mostrarlos en un lienzo desplazable, y manejar la limpieza de las imágenes extraídas cuando se cierra la aplicación.
Para obtener más detalles sobre la biblioteca IronPDF for Python, consulte la documentación.
Descargue e instale la biblioteca IronPDF for Python y obtenga también una prueba gratuita para probar toda su funcionalidad en el desarrollo comercial.