`

JapertReports & iReport的开源报表实战

阅读更多

JasperReports+iReports ,  类似于CrystalReport的开源报表系统,最主要能帮助我们在设计时把数据和表示分开,帮助我们实现Web报表的分页打印,分组合计,变量的加减处理,输出的格式化,还有导出Excel、pdf等,反正用过了的人都不肯回去重新自己画html页面出报表了。

    google上有入门教程,非常容易。但一遇到复杂的报表,入门那套很快就玩不转了,如果没有中级的研究,可能又得乖乖回去用html画报表。
    首先网上有一份JasperReport收费文档, 不过老实说,这份文档收费的话显得太单薄了。
   
    1.自定义数据源

    1.1 为什么要自定义数据源
    简单的报表,当然用不着自定义数据源。但查询复杂起来时,还死守着一条SQL写完会让SQL变得又长又难读,从来都最讨厌别人在SQL上炫技。 这时候,把查询分开执行,每个查询只负责向VO(值对象Bean)赋值若干个列,程序就会清晰很多。而且,相近的查询还可以进一步封装在一个Reporter类里,提供给报表内或者报表之间重用。更何况,有些情况根本不可能一条SQL里写完,而放在Java程序里处理却轻松自在。 
    搞定了可分解重用的数据源后,我才真正敢把JasperReports用在我们的系统上,否则,无法想象怎么维护那么多的SQL.

    1.2 自定义数据源的机制
dori.jasper.engine.JRDataSource 接口非常简单,只要实现两个方法:

public boolean next() throws JRException;
public Object getFieldValue(JRField jrField) throws JRException;
       看函数名字都知道其意义了。所幸,我们连这两个方法都不用实现,Jaspert已经有两个关于VO Bean的实现了。它们是dori.jasper.engine.data.JRBeanArrayDataSource和dori.jasper.engine.data.JRBeanCollectionDataSource
       看名字可知,一个用Array来放bean,一个用Collection 。
 
       很可惜如果VO有内嵌对象,也不能用$F{order.customer.name}这样的语法读取。
       另外Hibernate的HQL查询,如果返回多个对象时,每一row是Object[],只能按index而不能按名取值,也就不支持getFileldValue(field)了,hibernate.org上有折衷的方法,但都不好。

     1.3 Sample代码与解释
//封装了大量查询的reporter类
MooncakeReporter mooncakeReporter = new MooncakeReporter();
//建立VO的Map,因为需要多次执行查询,需要快速找回VO来赋值,因此采用Map.
Map map = new HashMap();
rs = mooncakeReporter.findAllVaildProduct();
while (rs.next())
{
  MooncakeVO mooncakeVO = new MooncakeVO();
  String goods_no = rs.getString("goods_no");
  String goods_name = rs.getString("name"); 
       mooncakeVO.setName(goods_name);
       mooncakeVO.setCode(code);

       map.put(goods_no, mooncakeVO);
}

//调用Reporter封装好的查询函数获取数据,并通过主键goods_no获得VO来赋值。
rs = mooncakeReporter.findSaleOrderByShopType("shop");
while (rs.next())
{
   String goods_no = rs.getString("goods_no");
   MooncakeVO mooncakeVO = (MooncakeVO) map.get(goods_no);
   if (mooncakeVO != null)
   {
      mooncakeVO.setShopCount(new Integer(rs.getInt("count")));
   }
}

//如此重复执行查询若干步
.....

//因为JRBeanCollectionDataSource需要Collection或者Array,把Map转化为List。
List result = new ArrayList(map.values());

//对result进行排序,通过BeanUtils的beanComparator来实现,在下一小节会讲到。
Collections.sort(result, new BeanComparator("code"));

//最后把result赋给JRBeanCollectionDataSource
JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, parameters, new JRBeanCollectionDataSource(result));

 

 

    1.4 扩展
    1.用BeanComparator进行排序
      用map来存放的VO是没有顺序的,必须对其进行排序。 用jakata commons-beanutils的BeanComparator类,可以动态改变排序的列,比自己实现Compare()接口好。

  Collections.sort(result, new BeanComparator("code"));

     对于"Order by lastName, firstName"的情形,还可以写成这样,其中ComparatorChain属于jakata commons-collections包。

     ArrayList sortFields = new ArrayList();
     sortFields.add(new BeanComparator("lastName"));
     sortFields.add(new BeanComparator("firstName"));
     ComparatorChain multiSort = new ComparatorChain(sortFields);
     Collections.sort(rows,multiSort); 

3.iReport报表的快速设计

2.<box>元素,终于不用手工划表格线了

   iReports终于出了0.41版,支持 JasperReports 0.64.

     JasperReports 0.64为什么这么重要?因为从0.63开始,JasperReports支持了千呼万唤始出来的box属性,可以像其他商业报表工具那样,设置表格的四周是否有线.而在以前,虽然人人都说神仙好,但一想起要手工划线, 还要精确的在两个field之间在留1个像素,就头皮一阵阵发麻.

     另外,新的box在excel下也表现良好,不再需要为Html和Excel制作两个不同的模版文件.

 

  一开始什么都不懂,对着满屏的元素,拖拉半天才把它对齐,差点就用不下去了。 
       2.1 快速整理,对齐报表内的元素
      这里示范最快捷的方法:
      1.点击随便一个要对齐的元素,左边的文档结构列表里相应的report session会打开
      2.用shift键选择该session里的所有元素
      3.ctrl+shift+l, ctrl+shift+向上箭头

      原来杂乱无章的元素一下子排齐了。
      在报表里增加或删除元素后,用此法都可快速重新对齐页面。
      其中第1,2步是快速批量选择所有元素,你也可以用鼠标拉框框选,或者按shift键一个一个选。
      第3步分别是左对齐和上对齐,都会向第一个选择的元素看齐。

 

       2.2 批量修改元素属性
       和很多网页编辑器一样,可以同时选择多个元素然后点选属性批量修改。

 

       2.3 iReport,UltraEdit双管齐下修改报表变量
       当变量比较多时,用Ultraedit直接Copy Paste就要比用iReport来增加filed和varible快很多。但用UltraEdit要注意以下两个问题:一是要注意Encoding,二是一个很奇怪的现象,iReport编译后,UltraEdit打开的文件第一句<!--l version="1.0" encoding="UTF-8-->最左边的"<!--丢失不见了,要手工替它补上。<-->

4.导出Excel文件

    刚开始导出的Excel文件叫人无比失望, 一个交得出去的Excel文件起码应该:
   1.所有的Field要撑满所在Band的高度,不要留空隙
   2.所有对象选成透明Transparent
   3.设置参数

     exporter.setParameter(JRXlsExporterParameter.IS_REMOVE_EMPTY_SPACE_BETWEEN_ROWS,
                    Boolean.TRUE);
     exporter.setParameter(JRXlsExporterParameter.IS_WHITE_PAGE_BACKGROUND, 
                    Boolean.FALSE);


   

5.JasperReports的一些补充     

 5.1 输出GBK字符集
         

exporter.setParameter(JRExporterParameter.CHARACTER_ENCODING, "GBK");



  5.2 定义filed显示的Pattern
        比如取小数后两位,财务计数法(每3位一个,号)等,如果ireport提供的pattern不爽,还可以直接改Xml文件

  5.3 Expresstion用三目运算符实现简单的if-else选择
        有些情况比如分母不能为0的判断,可以用三目运算符搞定,不一定要劳烦VO来计算。 

  5.4 批量编译文件
        ireport的Plug-in里有批量编译目录下所有文件的命令
                                                                                                                                       江南白衣

分享到:
评论

相关推荐

    ireport子报表嵌套

    iReport 子报表嵌套技术详解 iReport 子报表嵌套技术是 ireport 提供的一种高级功能,通过子报表技术我们可以创建复杂的报表,实现多对一的数据展示问题。在本文中,我们将通过 ireport 子报表技术,实现自有房产...

    iReport 报表、子报表、主从报表、合计、实例解析

    iReport 报表、子报表、主从报表、合计、实例解析1. 开发使用步骤(iReport4.1)... 2 4.1. JasperReport 和iReport的介绍... 2 4.1.1. JasperReport 简介... 3 4.1.2. iReport 简介... 3 4.1.2.1. iReport几个重要...

    JasperReport+iReport高级报表设计实战

    JasperReport是一款强大的开源报表生成工具,而iReport则是它的可视化设计界面,降低了报表设计的复杂度。本文将深入探讨iReport的高级功能,特别是针对复杂报表设计和数据源的配置。 1. **iReport 概览** iReport...

    ireport 子报表,行合并实例

    IReport和JasperReport是两个非常流行的Java报表工具,它们能够帮助开发者创建复杂、美观且功能丰富的报表。本篇将深入探讨如何利用IReport来实现子报表以及行合并的实例。 首先,IReport是一款基于GUI的报表设计...

    ireport交叉报表自定义排序

    ### iReport交叉报表自定义排序 #### 背景与问题描述 在处理复杂的报表设计时,特别是使用iReport工具创建交叉报表(Crosstab)的过程中,常常会遇到需要对数据进行特定排序的需求。默认情况下,交叉报表中的数据...

    ireport导出报表.pdf

    在本部分中,我们可以识别出关于iReport工具导出报表为PDF格式的一系列操作细节和知识点。iReport是一个报表设计工具,可以用来创建复杂的报表,并且可以将报表导出为多种格式,包括PDF和HTML。下面,我们将详细讲解...

    ireport交叉报表

    iReport是一款强大的开源报表设计工具,主要用于设计和创建复杂的报表。它支持多种数据源(如JDBC、XML、CSV等),并能生成各种格式的输出文件(PDF、HTML、Excel等)。通过iReport设计的报表不仅样式丰富,而且功能...

    关于ireport交叉报表

    iReport交叉报表详细知识点 iReport交叉报表是iReport JasperReports1.1.1版本中新增加的功能之一,它允许用户创建交叉报表,即使报表的行和列都是从数据库中读取的,而不是普通那种列固定行是从数据库中读取。下面...

    Ireport子报表学习例子

    Ireport是一款开源的报告设计工具,它允许开发者通过直观的图形界面来创建复杂的JavaServer Pages (JSP) 和PDF报告。在这个例子中,你将学到如何在Ireport中创建子报表,这在处理大型复杂报告时非常有用,因为子报表...

    iReport制作报表教程

    JasperReports是一个开源的Java报表库,它允许开发者生成静态和交互式的报表。它可以嵌入到Java应用程序、Web应用或者独立运行,提供PDF、HTML、Excel、CSV等多种格式的报表导出。 iReport作为JasperReports的可视...

    ireport利用jsp导出excel&pdf;报表源代码

    iReport是一款强大的开源报表设计工具,它基于JasperReports库,允许开发者使用Java和SQL来创建复杂的报告。本教程将详细介绍如何利用iReport和JSP在服务器端生成Excel和PDF格式的报表。 首先,理解iReport的核心...

    ireport报表参数传到子表步骤

    在iReport设计报表时,有时候我们需要将主报表的数据传递给子报表,以便子报表能够根据这些参数进行定制化的数据查询和展示。这个过程涉及到的主要知识点是报表参数的传递,也就是所谓的"传参"。以下是对这个过程的...

    iReport web报表开发实例

    iReport是一款强大的开源报表设计工具,它主要用于设计JasperReports报表,这些报表可以在Web应用程序中无缝集成,提供丰富的数据可视化和分析功能。本资源提供的"iReport web报表开发实例"是一份详尽的实践教程,...

    iReport开发报表详细设计说明书

    iReport是一款专为JasperReports设计的开源报表生成工具,完全使用Java编写,可以在SourceForge上找到。JasperReports是一个强大的报表生成库,能够解析XML文件生成Jasper文件,然后结合动态数据,输出HTML、PDF等...

    iReport分组报表

    iReport是一款强大的报告设计工具,尤其在Java平台上广泛使用,它是JasperReports库的一部分,用于创建复杂的报表设计。本文将深入探讨如何利用iReport的分组功能以及Print Repeated Values属性来创建高效的分组报表...

    ireport jfreechart 报表 录像

    iReport是一款基于Java的开源报表设计工具,常用于创建复杂的SQL查询、自定义报表样式以及数据可视化。JFreeChart则是Java领域中一个广泛使用的图表库,可以生成各种类型的图表,如柱状图、饼图、线图等。当这两者...

    iReport2.0.5报表工具

    iReport2.0.5报表工具 这个版本更好用

    ireport 报表常见的问题解决方案

    ireport 是一款广泛使用的开源报表工具,它允许开发者创建复杂、美观的报表。编写此文档的目的是为了帮助开发者们解决在使用 ireport 过程中遇到的一些常见问题,从而提高开发效率。文档参考了网络上的基础资料和...

    java和ireport制作报表实例

    iReport是一款强大的开源报表设计工具,它可以与Java应用程序紧密结合,提供丰富的报表功能。 首先,我们需要了解Java在报表生成中的角色。Java作为一种强大的后端编程语言,负责处理业务逻辑和数据查询。在这个...

    ireport开发交叉报表资料及笔记

    Ireport是一款强大的开源报表设计工具,它是JasperReport库的一部分,专门用于创建复杂的报表,包括交叉报表。在这个资料中,我们将深入探讨ireport如何开发交叉报表,并结合实际项目经验进行讲解。 一、ireport...

Global site tag (gtag.js) - Google Analytics