JAVA:Excel文档转无水印PDF文档

背景

新年初始,万物复苏,正月未过,给大家拜个晚年了!
一个小功能,分享一下。

准备

首先下载文件
链接: https://pan.baidu.com/s/1xvZYc13QVl1OtvFZ13gyDQ .
提取码: gkrc
JAVA:Excel文档转无水印PDF文档

我这里用的是Aspose的jar包,因为它是收费的所以不交钱会有水印,需要自己破解一下。破解用到的文件就是下载中的xml文件。

实现

将文件放到下图所示文件。
JAVA:Excel文档转无水印PDF文档

package com.demo.demo.controller;

import com.aspose.cells.License;
import com.aspose.cells.PdfSaveOptions;
import com.aspose.cells.Workbook;

import java.io.FileOutputStream;
import java.io.InputStream;

/**
 * @ClassName ExcelToPdfUtil
 * 功能详细描述:
 * @Author GuoZiYue
 * @Date 2021/2/18 11:08
 * @Version 1.0
 */
public class ExcelToPdfUtil {

    /**
     * excel 转为pdf 输出。
     *
     * @param sourceFilePath  excel文件
     * @param desFilePathd  pad 输出文件目录
     */
    public static void excel2pdf(String sourceFilePath, String desFilePathd ){
        if (!getLicense()) { // 验证License 若不验证则转化出的pdf文档会有水印产生
            return;
        }
        try {
            Workbook wb = new Workbook(sourceFilePath);// 原始excel路径

            FileOutputStream fileOS = new FileOutputStream(desFilePathd);
            PdfSaveOptions pdfSaveOptions = new PdfSaveOptions();
            pdfSaveOptions.setOnePagePerSheet(true);
            int sheetCount = wb.getWorksheets().getCount();
            int[] showSheets=new int[sheetCount];
            for (int i = 0; i < sheetCount; i++) {
                showSheets[i]=i;
            }
            //隐藏workbook中不需要的sheet页。
            autoDraw(wb,showSheets);
            printSheetPage(wb,showSheets);
            wb.save(fileOS, pdfSaveOptions);
            fileOS.flush();
            fileOS.close();
            System.out.println("完毕");

        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    public static boolean getLicense() {
        boolean result = false;
        try {
            InputStream is = FileController.class.getClassLoader().getResourceAsStream("\\templates\\license.xml");
            License aposeLic = new License();
            aposeLic.setLicense(is);
            result = true;
        } catch (Exception e) {
            e.printStackTrace();
        }
        return result;
    }


    /**
     * 设置打印的sheet 自动拉伸比例
     * @param wb
     * @param page 自动拉伸的页的sheet数组
     */
    public static void autoDraw(Workbook wb,int[] page){
        if(null!=page&&page.length>0){
            for (int i = 0; i < page.length; i++) {
                wb.getWorksheets().get(i).getHorizontalPageBreaks().clear();
                wb.getWorksheets().get(i).getVerticalPageBreaks().clear();
            }
        }
    }


    /**
     * 隐藏workbook中不需要的sheet页。
     * @param wb
     * @param page 显示页的sheet数组
     */
    public static void printSheetPage(Workbook wb,int[] page){
        for (int i= 1; i < wb.getWorksheets().getCount(); i++)  {
            wb.getWorksheets().get(i).setVisible(false);
        }
        if(null==page||page.length==0){
            wb.getWorksheets().get(0).setVisible(true);
        }else{
            for (int i = 0; i < page.length; i++) {
                wb.getWorksheets().get(i).setVisible(true);
            }
        }
    }
}

它支持多sheet转pdf,每个sheet分为一页。

调用

public static void main(String[] args) {
        String sourceFilePath="C:/excel2pdf/aa.xlsx";
        String desFilePath="d:/rest222.pdf";
        ExcelToPdfUtil.excel2pdf(sourceFilePath,desFilePath);
    }

直接调方法就行。

上一篇:Java 将XML转为Excel方法介绍


下一篇:python+selenium 活动页面监控(获取活动页面商品链接,商品名称价格,自动加购核算总价)