apatch POI excel---->pdf

来源:互联网 发布:西昊 ergomax 知乎 编辑:程序博客网 时间:2024/05/02 01:35

apatch POI  excel---->pdf


第1步

需要用的软件以及jar包
 OpenOffice 

jar下载地址
http://www.java2s.com/Code/Jar/c/Downloadcommonsio24jar.htm

poi-3.9.jar
jodconverter-2.2.2.jar
openoffice-ridl-3.1.0.jar
nlog4j-1.2.25.jar
commons-io-2.4.jar
commons-codec-1.7.jar


OpenOffice 4\program\classes\
ridl.jar
unoloader.jar
juh.jar
jurt.jar
officebean.jar
unoil.jar


第2步
启动OpenOffice服务,启动该服务后  在任务管理器中能找到soffice.exe
比如我的OpenOffice安装在C:\Program Files (x86)\下,
cmd,进入C:\Program Files (x86)\OpenOffice 4\program


在输入以下命令执行即可启动:
soffice -headless -accept="socket,host=127.0.0.1,port=8100;urp;" -nofirststartwizar


启动后 可以用命令  查看 有没有启动 8100端口
netsata -a 这个命令能监视所有端口

第3步
package test;

import java.awt.image.BufferedImage;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.ConnectException;
import java.util.Iterator;


import javax.imageio.ImageIO;


import org.apache.poi.hssf.usermodel.HSSFClientAnchor;
import org.apache.poi.hssf.usermodel.HSSFPatriarch;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;


import com.artofsolving.jodconverter.DefaultDocumentFormatRegistry;
import com.artofsolving.jodconverter.DocumentConverter;
import com.artofsolving.jodconverter.openoffice.connection.OpenOfficeConnection;
import com.artofsolving.jodconverter.openoffice.connection.SocketOpenOfficeConnection;
import com.artofsolving.jodconverter.openoffice.converter.OpenOfficeDocumentConverter;


public class Poi01 {


public static void main(String[] args) throws IOException {
// TODO Auto-generated method stub


test();
// office2PDF("d://test2-1.xls","d://test2-1.pdf");
}


private static void test() throws IOException {
// TODO Auto-generated method stub
// Excelファイルを読み込む
InputStream excel = new FileInputStream("d://test2-1.xls");


// ワークブックを開く
Workbook workbook = new HSSFWorkbook(excel);


// 最初のシートを開く
// Sheet sheet = workbook.getSheetAt(0);
HSSFSheet sheet = (HSSFSheet) workbook.getSheetAt(0);


// セル内に埋め込まれている置換文字を置換
for (Iterator<Row> sheetIte = sheet.iterator(); sheetIte.hasNext();) {
// 行を取得
Row row = sheetIte.next();


for (Iterator<Cell> cellIte = row.iterator(); cellIte.hasNext();) {
// セルを取得
Cell cell = cellIte.next();


// 文字列タイプのセルのみを対象
if (cell.getCellType() != Cell.CELL_TYPE_STRING) {
continue;
}


if (cell.getStringCellValue().equals("#NAME#")) {
// 「#NAME#」を置換
cell.setCellValue("山田 太郎");
}
if (cell.getStringCellValue().equals("${ID}")) {
// 「#NAME#」を置換
cell.setCellValue("20161001");
}
if (cell.getStringCellValue().equals("${NAME}")) {
// 「#NAME#」を置換
cell.setCellValue("cuichangsi");
}
if (cell.getStringCellValue().equals("${pic}")) {
// 「#NAME#」を置換
// CellRangeAddress ca=cell.getArrayFormulaRange();
System.out.println("aaaaaaaaaaa");
// cell.setCellValue("cuichangsi");
picc(sheet,(HSSFWorkbook)workbook);
}


}
}



///////////////////
// バッファ内にExcelの内容を書き出す
ByteArrayOutputStream buff = new ByteArrayOutputStream();
workbook.write(buff);


// PDF変換時に渡すInputStreamを用意
ByteArrayInputStream in = new ByteArrayInputStream(buff.toByteArray());
buff.close();
excel.close();


// PDFの出力先を開く
FileOutputStream out = new FileOutputStream("d:/temp/test.pdf");

String OpenOffice_HOME = "C:\\Program Files\\OpenOffice 4\\";//这里是OpenOffice的安装目录, 在我的项目中,为了便于拓展接口,没有直接写成这个样子,但是这样是绝对没问题的  
        // 如果从文件中读取的URL地址最后一个字符不是 '\',则添加'\'  
        if (OpenOffice_HOME.charAt(OpenOffice_HOME.length() - 1) != '\\') {  
            OpenOffice_HOME += "\\";  
        }  
        // 启动OpenOffice的服务  
        String command = OpenOffice_HOME  
//                + "program\\soffice.exe -headless -accept=\"socket,host=127.0.0.1,port=8100;urp;\"";  
        + "program\\soffice -headless -accept=\"socket,host=127.0.0.1,port=8100;urp;-nofirststartwizar";  
        Process pro = Runtime.getRuntime().exec(command);  
        // connect to an OpenOffice.org instance running on port 8100  
        SocketOpenOfficeConnection con = new SocketOpenOfficeConnection(  
                "127.0.0.1", 8100);  
        con.connect(); 


// OpenOfficeに接続(localhostの8100番ポート)
// SocketOpenOfficeConnection con = new SocketOpenOfficeConnection(8100);
// con.connect();


try {
   // ExcelからPDFへ変換
   DocumentConverter converter = new OpenOfficeDocumentConverter(con);
   converter.convert(
           in, new DefaultDocumentFormatRegistry().getFormatByFileExtension("xls"),
           out, new DefaultDocumentFormatRegistry().getFormatByFileExtension("pdf")
   );
} catch (Exception e) {
   e.printStackTrace();
} finally {
   // OpenOfficeから切断
   // ここで確実に切断しないとスレッドが終了しません
   con.disconnect();
// 关闭OpenOffice服务的进程  
            pro.destroy();
}


out.flush();
out.close();
in.close();


}

static void picc(Sheet sheet1,HSSFWorkbook wb){

FileOutputStream fileOut = null;     
         BufferedImage bufferImg = null;     
        //先把读进来的图片放到一个ByteArrayOutputStream中,以便产生ByteArray    
        try {  
            ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream();     
            bufferImg = ImageIO.read(new File("C:\\Users\\Administrator\\Desktop\\cuichangsiJLPT.JPG"));     
            ImageIO.write(bufferImg, "jpg", byteArrayOut);  
              
//            HSSFWorkbook wb = new HSSFWorkbook();     
//            HSSFSheet sheet1 = wb.createSheet("test picture");    
            //画图的顶级管理器,一个sheet只能获取一个(一定要注意这点)  
            HSSFPatriarch patriarch = (HSSFPatriarch) sheet1.createDrawingPatriarch();     
//            HSSFPatriarch patriarch = null;     
            //anchor主要用于设置图片的属性  
            HSSFClientAnchor anchor = new HSSFClientAnchor(0, 0, 0, 0,(short) 1, 11, (short) 7, 25);     
            anchor.setAnchorType(3);     
            //插入图片    
            patriarch.createPicture(anchor, wb.addPicture(byteArrayOut.toByteArray(), HSSFWorkbook.PICTURE_TYPE_JPEG));   
//            fileOut = new FileOutputStream("D:/测试Excel.xls");     
            // 写入excel文件     
//             wb.write(fileOut);     
             System.out.println("----Excle文件已生成------");  
        } catch (Exception e) {  
            e.printStackTrace();  
        }finally{  
            if(fileOut != null){  
                 try {  
                    fileOut.close();  
                } catch (IOException e) {  
                    e.printStackTrace();  
                }  
            }  
        } 
}


/** 
     * 将Office文档转换为PDF. 运行该函数需要用到OpenOffice, OpenOffice下载地址为 
     * http://www.openoffice.org/ 
     *  
     * <pre> 
     * 方法示例: 
     * String sourcePath = "F:\\office\\source.doc"; 
     * String destFile = "F:\\pdf\\dest.pdf"; 
     * Converter.office2PDF(sourcePath, destFile); 
     * </pre> 
     *  
     * @param sourceFile 
     *            源文件, 绝对路径. 可以是Office2003-2007全部格式的文档, Office2010的没测试. 包括.doc, 
     *            .docx, .xls, .xlsx, .ppt, .pptx等. 示例: F:\\office\\source.doc 
     * @param destFile 
     *            目标文件. 绝对路径. 示例: F:\\pdf\\dest.pdf 
     * @return 操作成功与否的提示信息. 如果返回 -1, 表示找不到源文件, 或url.properties配置错误; 如果返回 0, 
     *         则表示操作成功; 返回1, 则表示转换失败 
     */  
    public static int office2PDF(String sourceFile, String destFile) {  
        try {  
            File inputFile = new File(sourceFile);  
            if (!inputFile.exists()) {  
                return -1;// 找不到源文件, 则返回-1  
            }  
  
            // 如果目标路径不存在, 则新建该路径  
            File outputFile = new File(destFile);  
            if (!outputFile.getParentFile().exists()) {  
                outputFile.getParentFile().mkdirs();  
            }  
  
            String OpenOffice_HOME = "D:\\Program Files\\OpenOffice 4";//这里是OpenOffice的安装目录, 在我的项目中,为了便于拓展接口,没有直接写成这个样子,但是这样是绝对没问题的  
            // 如果从文件中读取的URL地址最后一个字符不是 '\',则添加'\'  
            if (OpenOffice_HOME.charAt(OpenOffice_HOME.length() - 1) != '\\') {  
                OpenOffice_HOME += "\\";  
            }  
            // 启动OpenOffice的服务  
            String command = OpenOffice_HOME  
                    + "program\\soffice.exe -headless -accept=\"socket,host=127.0.0.1,port=8100;urp;\"";  
            Process pro = Runtime.getRuntime().exec(command);  
            // connect to an OpenOffice.org instance running on port 8100  
            OpenOfficeConnection connection = new SocketOpenOfficeConnection(  
                    "127.0.0.1", 8100);  
            connection.connect();  
  
            // convert  
            DocumentConverter converter = new OpenOfficeDocumentConverter(  
                    connection);  
            converter.convert(inputFile, outputFile);  
  
            // close the connection  
            connection.disconnect();  
            // 关闭OpenOffice服务的进程  
//            pro.destroy();  
  
            return 0;  
//        } catch (FileNotFoundException e) {  
//            e.printStackTrace();  
//            return -1;  
        } catch (ConnectException e) {  
            e.printStackTrace();  
        } catch (IOException e) {  
            e.printStackTrace();  
        }  
  
        return 1;  
    }  
}
0 0
原创粉丝点击