用Python编写GUI程序将JPEG文件按文件名顺序插入PDF文件

news2025/1/9 1:06:36

在Python编程中,处理文件和图像是常见的任务之一。最近,我遇到了一个有趣的问题:如何通过编写一个GUI程序来将一个文件夹中的JPEG文件按文件名顺序插入到一个新的PDF文件中?在这篇博客中,我将分享我使用Python、wxPython模块和reportlab库实现这一功能的经验。

C:\pythoncode\new\jpeg2pdf.py

 准备工作

在开始编写代码之前,我们需要安装两个Python库:wxPython和reportlab。你可以使用pip命令进行安装:

pip install wxPython reportlab

 

 编写GUI程序

首先,我们创建一个简单的GUI界面,包含一个文件夹选择器和一个创建PDF按钮。用户可以通过文件夹选择器选择包含JPEG文件的文件夹,然后点击创建PDF按钮进行操作。

import os
import wx
from reportlab.pdfgen import canvas
from reportlab.lib.pagesizes import letter
from reportlab.lib.utils import ImageReader

class PdfCreatorFrame(wx.Frame):
    def __init__(self, parent, title):
        super(PdfCreatorFrame, self).__init__(parent, title=title, size=(400, 200))

        self.panel = wx.Panel(self)
        self.folder_picker = wx.DirPickerCtrl(self.panel, message="选择要插入的文件夹",
                                              style=wx.DIRP_USE_TEXTCTRL)
        self.create_pdf_button = wx.Button(self.panel, label="创建PDF", size=(100, 30))
        self.create_pdf_button.Bind(wx.EVT_BUTTON, self.on_create_pdf)

        self.status_text = wx.StaticText(self.panel, label="等待选择文件夹...")
        self.status_text.Wrap(380)

        sizer = wx.BoxSizer(wx.VERTICAL)
        sizer.Add(self.folder_picker, 0, wx.EXPAND | wx.ALL, 10)
        sizer.Add(self.create_pdf_button, 0, wx.ALIGN_CENTER | wx.TOP | wx.BOTTOM, 10)
        sizer.Add(self.status_text, 0, wx.ALIGN_CENTER | wx.ALL, 10)
        self.panel.SetSizer(sizer)

    def on_create_pdf(self, event):
        folder_path = self.folder_picker.GetPath()
        if not folder_path:
            self.status_text.SetLabel("请选择文件夹!")
            return

        jpeg_files = [f for f in os.listdir(folder_path) if f.lower().endswith('.jpg') or f.lower().endswith('.jpeg')]
        if not jpeg_files:
            self.status_text.SetLabel("文件夹中没有JPEG文件!")
            return

        pdf_path = os.path.join(folder_path, 'output.pdf')
        c = canvas.Canvas(pdf_path, pagesize=letter)

        sorted_files = sorted(jpeg_files)
        for idx, jpeg_file in enumerate(sorted_files):
            jpeg_path = os.path.join(folder_path, jpeg_file)
            img = ImageReader(jpeg_path)
            c.setPageSize(img.getSize())
            c.drawImage(img, 0, 0)
            if idx != len(sorted_files) - 1:
                c.showPage()

        c.save()
        self.status_text.SetLabel("PDF文件创建成功!")

if __name__ == '__main__':
    app = wx.App()
    frame = PdfCreatorFrame(None, title="JPEG插入PDF")
    frame.Show()
    app.MainLoop()

这段代码创建了一个名为`PdfCreatorFrame`的wxPython窗口类,其中包含了文件夹选择器和创建PDF按钮。当用户点击按钮时,程序会调用`on_create_pdf`方法来实现文件处理逻辑。

实现功能逻辑

在`on_create_pdf`方法中,我们首先获取用户选择的文件夹路径,并检查是否存在JPEG格式的图片文件。然后,我们使用reportlab库中的canvas类来创建一个新的PDF文件,并将文件夹中的JPEG文件按文件名顺序插入到PDF中。

   def on_create_pdf(self, event):
        folder_path = self.folder_picker.GetPath()
        if not folder_path:
            self.status_text.SetLabel("请选择文件夹!")
            return

        jpeg_files = [f for f in os.listdir(folder_path) if f.lower().endswith('.jpg') or f.lower().endswith('.jpeg')]
        if not jpeg_files:
            self.status_text.SetLabel("文件夹中没有JPEG文件!")
            return

        pdf_path = os.path.join(folder_path, 'output.pdf')
        c = canvas.Canvas(pdf_path, pagesize=letter)

        sorted_files = sorted(jpeg_files)
        for idx, jpeg_file in enumerate(sorted_files):
            jpeg_path = os.path.join(folder_path, jpeg_file)
            img = ImageReader(jpeg_path)
            c.setPageSize(img.getSize())
            c.drawImage(img, 0, 0)
            if idx != len(sorted_files) - 1:
                c.showPage()

        c.save()
        self.status_text.SetLabel("PDF文件创建成功!")

 

这部分代码逻辑简单明了:遍历选定文件夹下所有的JPEG文件,将其按文件名排序并逐个插入到PDF文件中。

 测试与运行

完成代码编写后,我们可以运行程序进行测试。当程序启动后,选择包含JPEG文件的文件夹,点击创建PDF按钮,程序将会按文件名顺序将所有的JPEG文件插入到一个新的PDF文件中。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1591445.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于springboot+vue+Mysql的论坛管理系统

开发语言:Java框架:springbootJDK版本:JDK1.8服务器:tomcat7数据库:mysql 5.7(一定要5.7版本)数据库工具:Navicat11开发软件:eclipse/myeclipse/ideaMaven包:…

【vue】v-model.lazy等(非实时渲染)

v-model&#xff1a;实时渲染v-model.lazy&#xff1a;失去焦点/按回车后&#xff0c;才渲染v-model.number&#xff1a;值转换为数字v-model.trim&#xff1a;去除首尾空格 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8&qu…

1.汉诺塔问题

C力扣 汉诺塔 class Solution { public:void hanota(vector<int>& a, vector<int>& b, vector<int>& c) {dfs(a,b,c,a.size());}void dfs(vector<int>& a, vector<int>& b, vector<int>& c,int n){if(n1){c.push…

图片批量高效缩放,批量缩放GIF图片并在缩放后以bmp位图保存

在这个数字化时代&#xff0c;图片已经成为我们生活和工作中不可或缺的一部分。无论是制作海报、设计网站&#xff0c;还是日常分享&#xff0c;我们都需要对图片进行处理。然而&#xff0c;面对大量的GIF图片&#xff0c;如何高效地进行缩放并转换为BMP位图&#xff0c;成为了…

链表中是否有环【c语言】

定义两个指针&#xff0c;一个每次跳跃两个节点&#xff08;快指针&#xff09;&#xff0c;另一个每次跳跃一个节点&#xff08;慢指针&#xff09;。如果存在环&#xff0c;他们最终会在环中的某个点相遇。如果链表无环&#xff0c;快指针将先到达链表尾端。 #include <s…

【智能算法】教与学优化算法 (TLBO)原理及实现

目录 1.背景2.算法原理2.1算法思想2.2算法过程 3.结果展示4.参考文献 1.背景 2012年&#xff0c;RV Rao等人受到班级内教师教学和学生学习启发&#xff0c;提出了教与学优化算法&#xff08;Teaching-learning-based Optimization, TLBO&#xff09;。 2.算法原理 2.1算法思…

2024最方便申请SSL证书方法介绍

申请SSL证书其实就像你去官方机构办个身份证&#xff0c;证明你的网站是合法且安全的。这里给你白话一点的简单步骤&#xff1a; 步骤一&#xff1a;确定需求 1. 域名&#xff1a;确保你有一个要申请证书的域名&#xff0c;就是你的网站地址&#xff0c;比如 www.example.com。…

【C++算法模板】数论:欧拉筛,线性查找质数的算法

文章目录 1&#xff09;传统找质数的方法&#xff08;优化筛选次数&#xff09;2&#xff09;欧拉筛 1&#xff09;传统找质数的方法&#xff08;优化筛选次数&#xff09; bool isPrime(int num) {for(int i2;i<sqrt(num)) {if(num%i0)return false;}return true; }如果要…

SSL、TLS和HTTPS:网络安全的重要基石

随着互联网的快速发展&#xff0c;网络安全问题日益凸显。为了保护数据在传输过程中的安全&#xff0c;各种加密协议和技术应运而生。SSL&#xff08;安全套接层&#xff09;、TLS&#xff08;传输层安全&#xff09;和HTTPS&#xff08;超文本传输安全协议&#xff09;是三个最…

Git 解决分支冲突

一、前言 一直习惯于 add commit push 的三步走&#xff0c;偶然间看到了一个评论说在 push 之前还有一个 pull&#xff0c;小小的疑问就埋在了我的心里。于是我就先了解了 pull 的工作原理&#xff0c;就是先拉取代码&#xff08;fetch&#xff09;再合并分支&#xff08;mer…

Xilinx Zynq UltraScale+ MPSoC无人机控制器

官方术语是无人驾驶飞行器&#xff08;UAV&#xff09;&#xff0c;这显然有点拗口&#xff0c;所以我们更喜欢说无人机。在过去的几十年里&#xff0c;无人机技术有了巨大的进步。我们为一个客户开发了一个无人机的飞行和视频控制器。 客户挑战 客户需要一种混合FPGA/CPU硬件&…

【matlab下的双目内窥镜标定与深度测距-双目成像原理】

【matlab下的双目内窥镜标定与深度测距-双目成像原理】 这里是目录 介绍坐标系关系相互关系推导三角测量 介绍 双目成像是一种利用两个摄像头或摄像头组成的系统同时捕捉场景信息的技术。它模拟了人类双眼视觉系统&#xff0c;通过两个视角获取的图像来计算深度信息&#xff…

基于分布式鲁棒性的多微网电氢混合储能容量优化配置——1

Optimal configuration of multi microgrid electric hydrogen hybrid energy storage capacity based on distributed robustness A B S T R A C T 储能与微电网相结合是解决分布式风能、太阳能资源不确定性、降低其对大电网安全稳定影响的重要技术路径。随着分布式风电和太阳…

【Hello算法】 > 第 2 关 >数据结构 之 数组与链表

数据结构 之 数组与链表 1&#xff1a;Understanding data structures &#xff01;——了解数据结构——1.1&#xff1a;Classification-分类-1.2&#xff1a;Type-类型- 2&#xff1a;Arrays are the bricks that make up the wall of data structures *——数组是组成数据结…

软件开发有那些陷阱?如何避坑?

引言 在当今数字化时代&#xff0c;软件开发已成为推动科技进步和商业发展的重要引擎。然而&#xff0c;软件开发并非一帆风顺&#xff0c;其中蕴藏着许多陷阱和挑战。如何避免这些陷阱&#xff0c;提高软件开发的效率和质量&#xff0c;成为开发者们面临的重要问题 本文将深入…

UltraScale 架构 SelectIO 资源之IODELAY与IOSERDES仿真与使用

平台&#xff1a;vivado2018.3 具体内容见ug571-ultrascale-selectio IDELAYE3 在调试超高速信号的时候&#xff0c;需要使用iodelayiserdes来调试校准输入信号。例如外部某ADC采样率为5GHZ&#xff0c;外部ADC使用2.5GHZ的时钟去采集输入信号。为了实现采集&#xff0c;adc芯…

【python】python基于Pygame扫雷游戏设计实现(源码+报告)【独一无二】

> &#x1f449;博__主&#x1f448;&#xff1a;米码收割机 &#x1f449;技__能&#x1f448;&#xff1a;C/Python语言 &#x1f449;公众号&#x1f448;&#xff1a;测试开发自动化【获取源码商业合作】 &#x1f449;荣__誉&#x1f448;&#xff1a;阿里云博客专家博…

AD7685BRMZRL7 16位 2.3V 低功耗模数转换器芯片 ADI

AD7685BRMZRL7是一款由ADI&#xff08;亚德诺&#xff09;公司生产的模数转换器&#xff08;ADC&#xff09;芯片。该芯片的主要功能是将模拟信号转换为数字信号&#xff0c;以便在数字系统中处理. AD7685BRMZRL7 规格信息&#xff1a; 制造商:Analog Devices Inc. 产品种类:模…

volatile是如何禁止指令进行重排序的

Further Reading &#xff1a; 内存屏障类型介绍&#xff08;StoreStore&#xff0c;StoreLoad&#xff0c;LoadLoad&#xff0c;LoadStore&#xff09; Further Reading &#xff1a; 什么是指令重排 重排序分为编译器重排序和处理器重排序。 为了实现volatile内存语义&#x…

本地开发nginx代理服务器(2024-04-10)

1、nginx 解释 nginx 是一个高性能的HTTP和反向代理服务器&#xff0c;同时也是一个IMAP/POP3/SMTP 代理服务器。 在性能上&#xff0c;Nginx占用很少的系统资源&#xff0c;能支持更多的并发连接&#xff0c;达到更高的访问效率&#xff1b; 在功能上&#xff0c;Nginx是优…