百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python Web开发中Excel转PDF文件(python将excel转pdf)

off999 2024-11-10 10:33 20 浏览 0 评论

在 Web 应用程序或者项目的某些批处理程序中,将 Excel 转换为 PDF 文件的需求是常见的。对于 Excel 转换 PDF 的方法,从使用方便性和开发效率上来讲,使用 Python 语言目前没有合适的方法来进行转换,所以必须借助使用其他语言的方法来实现,本次我们采用 Java 语言来进行 Excel 转换 PDF,然后由 Python 语言调用来实现整个转换过程。

开发工具

Idea

Java

Spire.XLS for Java

PyCharm

flask

1.Excel 转换 PDF

采用 Java 语言来实现,通过 Spire.XLS for Java 组件,组件下载地址:

https://www.e-iceblue.cn/Downloads/Free-Spire-XLS-JAVA.html

如下图:

开发工具采用 IDEA,项目结构如下图:

将下载的组件 Spire.Xls.jar 放到项目的libs目录下,并将jar文件引入项目,选择 File -> Project Structure,单击Modules,单击+,如下图:

Excel2PDF类代码:

package com.zhqy.excel2pdf;

import com.spire.xls.*;

public class Excel2PDF {
    public static void excel2pdf(String excelFileName, String pdfFileName) {
        //加载Excel文档
        Workbook wb = new Workbook();
        wb.loadFromFile(excelFileName);

        //调用方法保存为PDF格式
        wb.saveToFile(pdfFileName, FileFormat.PDF);
    }

    public static void workbook2pdf(String excelFileName, int workbookIndex, String pdfFileName) {
        //加载Excel文档
        Workbook wb = new Workbook();
        wb.loadFromFile(excelFileName);

        //获取第2个工作表
        Worksheet sheet = wb.getWorksheets().get(workbookIndex);
        //调用方法保存为PDF格式
        sheet.saveToPdf(pdfFileName);
    }
}

Main类代码:

package com.zhqy.excel2pdf;

public class Main {
    public static void main(String[] args) {
        if (args.length != 2 && args.length != 3) {
            System.out.println("Usage: java com.zhqy.excel2pdf.Main <excel file name> [<excel workbook index>] <pdf file name>");
            return;
        }
        String excelFileName, pdfFileName;
        int workbookIndex;
        excelFileName = args[0];
        if (args.length == 2) {
            pdfFileName = args[1];
            Excel2PDF.excel2pdf(excelFileName, pdfFileName);
        }
        if (args.length == 3) {
            workbookIndex = Integer.parseInt(args[1]);
            pdfFileName = args[2];
            Excel2PDF.workbook2pdf(excelFileName, workbookIndex, pdfFileName);
        }
    }
}

可以直接使用 Main 类进行命令行操作来完成转换工作。

将 Java 类打包,选择 File -> Project Structure,单击 Artifacts,如下图:

2.在 Python Web 项目中使用

Web 项目采用 flask 框架,具体的 flask 项目不在此赘述,Python 调用 Java 程序采用 jpype,安装:

pip3 install jpype1

在项目中增加一个包 utils,在包中创建 excel2pdf.py,代码如下:

# coding: utf-8
import jpype
import os

def excel2pdf(excel_file_name, pdf_file_name):
    # JVM默认路径、Jar文件路径
    jvm_path = jpype.getDefaultJVMPath()
    ext_classpath = '/excel2pdf.jar'
    jvm_arg = '-Djava.class.path=' + ext_classpath

    # 启动JVM
    if not jpype.isJVMStarted():
        jpype.startJVM(jvm_path, jvm_arg)

    # 测试输出
    jpype.java.lang.System.out.println('hello world! ')
    # Excel转PDF类
    Excel2PDF = jpype.JClass('com.zhqy.excel2pdf.Excel2PDF')
    Excel2PDF.excel2pdf(excel_file_name, pdf_file_name)


def workbook2pdf(excel_file_name, workbook_index, pdf_file_name):
    # JVM默认路径、Jar文件路径
    jvm_path = jpype.getDefaultJVMPath()
    ext_classpath = '/excel2pdf.jar'
    jvm_arg = '-Djava.class.path=' + ext_classpath

    # 启动JVM
    if not jpype.isJVMStarted():
        jpype.startJVM(jvm_path, jvm_arg)

    # 测试输出
    jpype.java.lang.System.out.println('hello world! ')
    # Excel转PDF类
    Excel2PDF = jpype.JClass('com.zhqy.excel2pdf.Excel2PDF')
    Excel2PDF.workbook2pdf(excel_file_name, workbook_index, pdf_file_name)

jar 文件需要复制到某个目录,本例中直接复制到了 python 项目所在磁盘的根目录,所以有下面的代码:

ext_classpath = '/excel2pdf.jar'

接下来就可以直接在 flask 项目中调用 utils 包中的方法进行文件格式转换。



相关推荐

第九章:Python文件操作与输入输出

9.1文件的基本操作9.1.1打开文件理论知识:在Python中,使用open()函数来打开文件。open()函数接受两个主要参数:文件名和打开模式。打开模式决定了文件如何被使用,常见的模式有:&...

Python的文件处理

一、文件处理的流程1.打开文件,得到文件句柄并赋值给一个变量2.通过句柄对文件进行操作3.关闭文件示例:d=open('abc')data1=d.read()pri...

Python处理文本的25个经典操作

Python处理文本的优势主要体现在其简洁性、功能强大和灵活性。具体来说,Python提供了丰富的库和工具,使得对文件的读写、处理变得轻而易举。简洁的文件操作接口Python通过内置的open()函数...

Python学不会来打我(84)python复制文件操作总结

上一篇文章我们分享了python读写文件的操作,主要用到了open()、read()、write()等方法。这一次是在文件读写的基础之上,我们分享文件的复制。#python##python自学##...

python 文件操作

1.检查目录/文件使用exists()方法来检查是否存在特定路径。如果存在,返回True;如果不存在,则返回False。此功能在os和pathlib模块中均可用,各自的用法如下。#os模块中e...

《文件操作(读写文件)》

一、文件操作基础1.open()函数核心语法file=open("filename.txt",mode="r",encoding="utf-8"...

栋察宇宙(二十一):Python 文件操作全解析

分享乐趣,传播快乐,增长见识,留下美好。亲爱的您,这里是LearingYard学苑!今天小编为大家带来“Python文件操作全解析”欢迎您的访问!Sharethefun,spreadthe...

值得学习练手的70个Python项目(附代码),太实用了

Python丰富的开发生态是它的一大优势,各种第三方库、框架和代码,都是前人造好的“轮子”,能够完成很多操作,让你的开发事半功倍。下面就给大家介绍70个通过Python构建的项目,以此来学习Pytho...

python图形化编程:猜数字的游戏

importrandomnum=random.randint(1,500)running=Truetimes=0##总的次数fromtkinterimport*##导入所有tki...

一文讲清Python Flask的Web编程知识

刚入坑Python做Web开发的新手,还在被配置臃肿、启动繁琐折磨?Flask这轻量级框架最近又火出圈,凭5行代码启动Web服务的极致简洁,让90后程序员小张直呼真香——毕竟他刚用这招把部署时间从半小...

用python 编写一个hello,world

第一种:交互式运行一个hello,world程序:这是写python的第一步,也是学习各类语言的第一步,就是用这种语言写一个hello,world程序.第一步,打开命令行窗口,输入python,第二步...

python编程:如何使用python代码绘制出哪些常见的机器学习图像?

专栏推荐绘图的变量单变量查看单变量最方便的无疑是displot()函数,默认绘制一个直方图,并你核密度估计(KDE)sns.set(color_codes=True)np.random.seed(su...

如何编写快速且更惯用的 Python 代码

Python因其可读性而受到称赞。这使它成为一种很好的第一语言,也是脚本和原型设计的流行选择。在这篇文章中,我们将研究一些可以使您的Python代码更具可读性和惯用性的技术。我不仅仅是pyt...

Python函数式编程的详细分析(代码示例)

本篇文章给大家带来的内容是关于Python函数式编程的详细分析(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。FunctionalProgramming,函数式编程。Py...

编程小白学做题:Python 的经典编程题及详解,附代码和注释(七)

适合Python3+的6道编程练习题(附详解)1.检查字符串是否以指定子串开头题目描述:判断字符串是否以给定子串开头(如"helloworld"以"hello&...

取消回复欢迎 发表评论: