【iReport+JasperReport】3.在Java工程中用jasper导出Excel报表

上一次我们使用JasperReport导出了PDF格式的报表文件,我们这次利用同样的jasper文件,来在硬盘中导出Excel报表。

实现导出的Java的详细代码请查看上一篇,这里只修改最后的启动类代码。

我们先回顾一下jasper的实际效果:
【iReport+JasperReport】3.在Java工程中用jasper导出Excel报表_第1张图片

然后我们修改一下启动类代码,之前打印pdf的代码为:
package com.cn.org.ireport.test;

import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.util.HashMap;
import java.util.Map;

import net.sf.jasperreports.engine.JRAbstractExporter;
import net.sf.jasperreports.engine.JRException;
import net.sf.jasperreports.engine.JRExporterParameter;
import net.sf.jasperreports.engine.JasperFillManager;
import net.sf.jasperreports.engine.JasperPrint;
import net.sf.jasperreports.engine.export.JRPdfExporter;
import net.sf.jasperreports.engine.export.JRPdfExporterParameter;

public class TestReportHere {
    public static void main(String[] args) {
        Map parameters=new HashMap();
        ByteArrayOutputStream outPut=new ByteArrayOutputStream();
        FileOutputStream outputStream=null;
        File file=new File("F:/Temp/report.xls");
        String reportModelFile="C:/Users/jack/report2.jasper";
        
        try {
            JasperPrint jasperPrint=JasperFillManager.fillReport(reportModelFile,
                    parameters,new ReportDataSource("男"));
            JRAbstractExporter exporter=new JRPdfExporter();
            
            //创建jasperPrint
            exporter.setParameter(JRExporterParameter.JASPER_PRINT, jasperPrint);
            //生成输出流
            exporter.setParameter(JRExporterParameter.OUTPUT_STREAM, outPut);
            //屏蔽copy功能
            exporter.setParameter(JRPdfExporterParameter.IS_ENCRYPTED,Boolean.TRUE);
            //加密
            exporter.setParameter(JRPdfExporterParameter.IS_128_BIT_KEY,Boolean.TRUE);
            exporter.exportReport();
            outputStream=new FileOutputStream(file);
            outputStream.write(outPut.toByteArray());
        } catch (JRException e) {
            e.printStackTrace();
        }catch (Exception e) {
            e.printStackTrace();
        }finally{
            try {
                outPut.flush();
                outPut.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
}
打印出的pdf效果为:


打印Excel报表,首先加入poi的依赖jar包(这里我使用的是poi-3.8-beta4-20110826.jar),然后将启动类代码中关于打印的逻辑修改,将JRPdfExporter改为JRXlsExporter,然后修改部分setParameter设置参数:
package com.cn.org.ireport.test;

import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.util.HashMap;
import java.util.Map;

import net.sf.jasperreports.engine.JRAbstractExporter;
import net.sf.jasperreports.engine.JRException;
import net.sf.jasperreports.engine.JRExporterParameter;
import net.sf.jasperreports.engine.JasperFillManager;
import net.sf.jasperreports.engine.JasperPrint;
import net.sf.jasperreports.engine.export.JRXlsExporter;
import net.sf.jasperreports.engine.export.JRXlsExporterParameter;

public class TestReportHere {
    public static void main(String[] args) {
        Map parameters=new HashMap();
        ByteArrayOutputStream outPut=new ByteArrayOutputStream();
        FileOutputStream outputStream=null;
        File file=new File("F:/Temp/report.xls");
        String reportModelFile="C:/Users/jack/report2.jasper";
        
        try {
            JasperPrint jasperPrint=JasperFillManager.fillReport(reportModelFile,
                    parameters,new ReportDataSource("男"));
        
        JRAbstractExporter exporter = new JRXlsExporter();
        //创建jasperPrint
            exporter.setParameter(JRExporterParameter.JASPER_PRINT,jasperPrint);
            //生成输出流
            exporter.setParameter(JRExporterParameter.OUTPUT_STREAM,outPut);
            //去除两行之前的空白
            exporter.setParameter(JRXlsExporterParameter.IS_REMOVE_EMPTY_SPACE_BETWEEN_ROWS,Boolean.TRUE);
            //设置所有页只打印到一个Sheet中
            exporter.setParameter(JRXlsExporterParameter.IS_ONE_PAGE_PER_SHEET,Boolean.FALSE);
            //设置Excel表格的背景颜色为默认的白色
            exporter.setParameter(JRXlsExporterParameter.IS_WHITE_PAGE_BACKGROUND,Boolean.FALSE);
            exporter.exportReport();
            outputStream=new FileOutputStream(file);
            outputStream.write(outPut.toByteArray());
        } catch (JRException e) {
            e.printStackTrace();
        }catch (Exception e) {
            e.printStackTrace();
        }finally{
            try {
                outPut.flush();
                outPut.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
}
打印出的效果为:

【iReport+JasperReport】3.在Java工程中用jasper导出Excel报表_第2张图片


效果可能没有pdf好看,这是因为原来我们只是设计为了打印pdf,如果要打印Excel,就要设计的更合理一些,这里我们仅仅为了演示效果。

其次JasperReport还可以打印出其他格式的报表,大家根据自己的需求去添加相应的jar包,修改部分逻辑即可,这里不再赘述。

转载请注明出处:http://blog.csdn.net/acmman/article/details/51828558

你可能感兴趣的:(【iReport+JasperReport】3.在Java工程中用jasper导出Excel报表)