使用aspose把各种文件转换成pdf

使用aspose把各种文件转换成pdfpackagecom.fh.util;importjava.io.File;importjava.io.FileInputStream;importjava.io.FileOutputStream;importjava.io.IOException;importjava.io.InputStream;importorg.apache.pdfbox.pdmodel.PD…

大家好,又见面了,我是你们的朋友全栈君。

package com.fh.util;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;

import org.apache.pdfbox.pdmodel.PDDocument;

import com.aspose.cells.Workbook;
import com.aspose.slides.Presentation;
import com.aspose.words.Document;
import com.lowagie.text.DocumentException;
import com.lowagie.text.Image;
import com.lowagie.text.PageSize;
import com.lowagie.text.pdf.PdfWriter;

/**
 * 
 * 使用的aspose包把文档转换成pdf工具类
 * @author dwm
 *2019-07-03
 */
public class Word2Pdf {
	
	public static void main(String[] args) {
//		excel2Pdf("F:\\aaa\\加班.xls","F:\\aaa\\加班.pdf") ;
	}
	
	 /**
     * 获取pdf文档的页数
     * @param pdfFilePath
     * @return
     */
    public static int getPdfPage(String pdfFilePath){
    	try{
    		// 判断输入文件是否存在
    		File file = new File(pdfFilePath);  
            if (!file.exists()) {  
                return 0;  
            }
            
            // 如果不是pdf直接返回0
            if (!FileUtil.getFileSufix(pdfFilePath).equals("pdf")) {  
                return 0;  
            }
            
            PDDocument pdf = PDDocument.load(file);
            return pdf.getPages().getCount();		//返回页数
            
    	}catch(Exception e){
    		e.printStackTrace();
    		return 0;
    	}
    }
	
	/**
	 * 使用aspose转换成pdf文件
	 * @param inputFile
	 * @param pdfFile
	 * @return
	 */
	public static boolean convertToPdfAsAspose(String inputFile, String pdfFile) {
		String suffix = FileUtil.getFileSufix(inputFile); //后缀
		File file = new File(inputFile) ;
		if(!file.exists()) {
			return false ;
		}
		if("pdf".equalsIgnoreCase(suffix)) {
			return false ;
		}
		
		//根据不同的文件转换成pdf文件
		if("doc".equalsIgnoreCase(suffix) || "docx".equalsIgnoreCase(suffix) || "txt".equalsIgnoreCase(suffix)) {
			return doc2pdf(inputFile,pdfFile) ;
		} else if("xls".equalsIgnoreCase(suffix) || "xlsx".equalsIgnoreCase(suffix)) {
			return excel2Pdf(inputFile, pdfFile);
		} else if("xls".equalsIgnoreCase(suffix) || "xlsx".equalsIgnoreCase(suffix)) {
			return excel2Pdf(inputFile, pdfFile);
		} else if (suffix.equalsIgnoreCase("png") || suffix.equalsIgnoreCase("jpg") 
        		|| suffix.equalsIgnoreCase("jpeg")) {  
            return img2PDF(inputFile, pdfFile);  
        } else {  
            return false;  
        }
	}
	
	/**
	 * aspose.word包获取配置
	 * @return
	 */
	public static boolean getWordLicense() {
        boolean result = false;
        InputStream is = null ;
        try {
        	is = Word2Pdf.class.getClassLoader().getResourceAsStream("license.xml"); // license.xml应放在..\WebRoot\WEB-INF\classes路径下
        	com.aspose.words.License aposeLic = new com.aspose.words.License();
            aposeLic.setLicense(is);
            result = true;
            is.close();
        } catch (Exception e) {
        	if(is != null) {
        		try {
					is.close() ;
				} catch (IOException e1) {
					// TODO Auto-generated catch block
					e1.printStackTrace();
				}
        	}
            e.printStackTrace();
        }
        return result; 
    }
	
	/**
	 * word文档转pdf
	 * @param inPath
	 * @param outPath
	 */
	 public static boolean doc2pdf(String inPath, String outPath) {
		 if (!getWordLicense()) { // 验证License 若不验证则转化出的pdf文档会有水印产生
			 return false;
	     }
		 FileOutputStream os = null ;
		 try {
            long old = System.currentTimeMillis();
            File file = new File(outPath); // 新建一个空白pdf文档
            os = new FileOutputStream(file);
            Document doc = new Document(inPath); // Address是将要被转化的word文档
            doc.save(os, com.aspose.words.SaveFormat.PDF);// 全面支持DOC, DOCX, OOXML, RTF HTML, OpenDocument, PDF,
                                         // EPUB, XPS, SWF 相互转换
            long now = System.currentTimeMillis();
            System.out.println("共耗时:" + ((now - old) / 1000.0) + "秒"); // 转化用时
            os.close();
		 } catch (Exception e) {
        	if(os != null) {
        		try {
					os.close();
				} catch (IOException e1) {
					e1.printStackTrace();
				}
        	}
            e.printStackTrace();
            return false ;
		 }
		 return true ;
	 }
	 
	 public static boolean getExcelLicense() {
		boolean result = false;
        InputStream is = null ;
        try {
        	is = Word2Pdf.class.getClassLoader().getResourceAsStream("license.xml"); // license.xml应放在..\WebRoot\WEB-INF\classes路径下
        	com.aspose.cells.License aposeLic = new com.aspose.cells.License();
            aposeLic.setLicense(is);
            result = true;
            is.close();
        } catch (Exception e) {
        	if(is != null) {
        		try {
					is.close() ;
				} catch (IOException e1) {
					// TODO Auto-generated catch block
					e1.printStackTrace();
				}
        	}
            e.printStackTrace();
        }
        return result; 
	 }
	 
	 /**
	  * asponse:excel转pdf
	  * @param excelPath
	  * @param pdfPath
	  */
	 public static boolean excel2Pdf(String excelPath, String pdfPath) {
			long old = System.currentTimeMillis();
			// 验证License
			if (!getExcelLicense()) {
				return false;
			}
			FileInputStream fileInputStream = null;
			FileOutputStream fileOutputStream = null;
			try {
				File excelFile = new File(excelPath);
				if (excelFile.exists()) {
					fileInputStream = new FileInputStream(excelFile);
					Workbook workbook = new Workbook(fileInputStream);
					File pdfFile = new File(pdfPath);
					fileOutputStream = new FileOutputStream(pdfFile);
					workbook.save(fileOutputStream, com.aspose.cells.SaveFormat.PDF);
					long now = System.currentTimeMillis();
					System.out.println("共耗时:" + ((now - old) / 1000.0) + "秒\n\n" + "文件保存在:" + pdfFile.getPath());
					return true ;
				} else {
					System.out.println("文件不存在");
					return false ;
				}
			} catch (Exception e) {
				e.printStackTrace();
				return false ;
			} finally {
				if (fileInputStream != null) {
					try {
						fileInputStream.close();
					} catch (IOException e) {
						e.printStackTrace();
					}
				}
				if (fileOutputStream != null) {
					try {
						fileOutputStream.close();
					} catch (IOException e) {
						e.printStackTrace();
					}
				}
			}
	}
	 
	 
	 public static boolean getPptLicense() {
		 boolean result = false;
		 InputStream is = null ;
		 try {
			 is = Word2Pdf.class.getClassLoader().getResourceAsStream("license.xml"); // license.xml应放在..\WebRoot\WEB-INF\classes路径下
			 com.aspose.slides.License aposeLic = new com.aspose.slides.License();
			 aposeLic.setLicense(is);
			 result = true;
			 is.close();
		 } catch (Exception e) {
			 if(is != null) {
				 try {
					 is.close() ;
				 } catch (IOException e1) {
					 // TODO Auto-generated catch block
					 e1.printStackTrace();
				 }
			 }
			 e.printStackTrace();
		 }
		 return result; 
	 }
	 /**
	  * aspose:ppt转pdf
	  * @param inPath
	  * @param outPath
	  */
	 public static void ppt2pdf(String inPath,String outPath) {
	    	
	    	// 验证License
			if (!getPptLicense()) {
			     return;
			}
			FileOutputStream fileOS = null ;
			try {
				long old = System.currentTimeMillis();
				File file = new File(outPath);// 输出pdf路径
				Presentation pres = new Presentation(inPath);//输入pdf路径         
				fileOS = new FileOutputStream(file);
				pres.save(fileOS, com.aspose.slides.SaveFormat.Pdf);
				fileOS.close();
			 
			    long now = System.currentTimeMillis();
			    System.out.println("共耗时:" + ((now - old) / 1000.0) + "秒\n\n" + "文件保存在:" + file.getPath()); //转化过程耗时
			} catch (Exception e) {
				if(fileOS != null) {
					try {
						fileOS.close();
					} catch (IOException e1) {
						e1.printStackTrace();
					} 
				}
			    e.printStackTrace();
			}
	 }
	 
	 //img转pdf
		public static boolean img2PDF(String imgFilePath, String pdfFilePath){
			File file = new File(imgFilePath);
			if (file.exists()) {
				com.lowagie.text.Document document = new com.lowagie.text.Document();
				FileOutputStream fos = null;
				try {
					fos = new FileOutputStream(pdfFilePath);
					PdfWriter.getInstance(document, fos);

					// 添加PDF文档的某些信息,比如作者,主题等等
					document.addAuthor("newprint");
					document.addSubject("test pdf.");
					// 设置文档的大小
					document.setPageSize(PageSize.A4);
					// 打开文档
					document.open();
					// 写入一段文字
					// document.add(new Paragraph("JUST TEST ..."));
					// 读取一个图片
					Image image = Image.getInstance(imgFilePath);
					float imageHeight = image.getScaledHeight();
					float imageWidth = image.getScaledWidth();
					int i = 0;
					while (imageHeight > 500 || imageWidth > 500) {
						image.scalePercent(100 - i);
						i++;
						imageHeight = image.getScaledHeight();
						imageWidth = image.getScaledWidth();
						System.out.println("imageHeight->" + imageHeight);
						System.out.println("imageWidth->" + imageWidth);
					}

					image.setAlignment(Image.ALIGN_CENTER);
					// //设置图片的绝对位置
					// image.setAbsolutePosition(0, 0);
					// image.scaleAbsolute(500, 400);
					// 插入一个图片
					document.add(image);
				} catch (DocumentException de) {
					System.out.println(de.getMessage());
				} catch (IOException ioe) {
					System.out.println(ioe.getMessage());
				}
				document.close();
				try {
					fos.flush();
					fos.close();
				} catch (IOException e) {
					e.printStackTrace();
				}
			
				return true;
			} else {
				return false;
			}
		}
	 
	 
	
}

此处提供转pdf的代码,不同文件转pdf或别的格式都需要不同的jar包,下载地址:在这里插入代码片
https://download.csdn.net/download/bianqing0305/11274829
其中包含lisence.xml

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/136167.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月4日 上午6:36
下一篇 2022年6月4日 上午6:36


相关推荐

  • Java面向对象的三大特征以及理解

    Java面向对象的三大特征以及理解Java面向对象的三大特征为:封装、继承和多态,本文说说我对三大特性的理解。1.封装Java中的封装是指一个类把自己内部的实现细节进行隐藏,只暴露对外的接口(setter和getter方法)。封装又分为属性的封装和方法的封装。把属性定义为私有的,它们通过setter和getter方法来对属性的值进行设定和获取。下面我举一个简单的封装例子publicclassPerson{priva…

    2022年7月25日
    10
  • java不求有功,但求无过—异常处理

    java不求有功,但求无过—异常处理

    2021年11月29日
    52
  • 盘点当下大热的 7 大 Github 机器学习『创新』项目

    盘点当下大热的 7 大 Github 机器学习『创新』项目本文将会分享近期发布的七大GitHub机器学习项目。这些项目广泛覆盖了机器学习的各个领域,包括自然语言处理(NLP)、计算机视觉、大数据等。最顶尖的Github机器学习项…

    2022年6月7日
    37
  • 2026年保姆级AI生成短剧操作教程(新手零门槛上手)

    2026年保姆级AI生成短剧操作教程(新手零门槛上手)

    2026年3月15日
    8
  • 计算机三级数据库技术复习资料总结

    计算机三级数据库技术复习资料总结第7章数据库及数据库对象一、创建及维护数据库1、两大类:系统数据库(自动创建和维护的):master:最重要的数据库,记录所有系统级信息,主要的信息都是存放在这。msdb:保存报警、作业、操作员等信息。(考的不多)model:所有创建数据库的模板。tempdb:临时数据库,每次启动SQL都会重新创建,因此不需要备份。Resource:只读数据库。(没见过考)用户数据库(用户创建和维护)经常考选择题:系统数据库如何备份?(未完成)2、数据库文件分类数据文件:主要数据文件:每个数据

    2022年6月18日
    29
  • ffprobe的翻译

    ffprobe的翻译ffprobe 使用详解 2014 05 3122 27 38 分类 架构设计与优化目录 1 语法 2 描述 3 选项 3 1 流指示符 3 2 通用选项 3 3 音视频选项 3 4 主选项 4 写入器 4 1 默认值 4 2compact csv4 3flat4 4ini4 5json4 6xml5 Timecode

    2026年3月16日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号