`

IReport 使用总结

F# 
阅读更多

首先ireport中大小写问题:

1、parameter中如果小写,引用也小写

2、$F{},一般都大写

3、子报表中引用父报表中查询出来的值时,只需要小写即可,即在子报表的parameter中只需要小写

一、iReport 中获取系统当前时间

1、选择 TextField 类型为 java.util.Date,选择TextField的Expression Class(类型)为 java.util.Date

2、在 pattern 中选择时间格式

3、在 TextField Expression 中写 java.util.Calendar.getInstance().getTime()


二、避免为空

方法一、在属性选项中找到 blank when null 即可

方法二、$F{ABB614}?$F{ABB614}:""

 

三、设置时间格式

方法一、可以使用内嵌函数截取字符串来显示

1、利用substring来截取 (针对String类型)

$F{AAE036}?(($F{AAE036}.toString()).substring(0,4)+"年"+($F{AAE036}.toString()).substring(4,6)+"月"+($F{AAE036}.toString()).substring(6,8)+"日"):""

2、利用内置的函数来取 (针对date类型)

"日期"+($F{ABB017}?String.valueOf($F{ABB017}.getYear()+1900)+"年"+String.valueOf($F{ABB017}.getMonth()+1)+"月"+$F{ABB017}.getDate():"")+"日

方法二、设置 Exception class 为date类型,然后 pattern 中设置时间格式,可以自己写,例如××××年××月××日,但是要注意,如果为空无法用 $F{ABB614}?$F{ABB614}:"",只能使用 blank when null 这种方法


四、在ireport中使用html中的标签

例如:<br> 

1、找到属性面板中的 markup 选择为html

2、在需要的地方加入<br>


五、使某个字段中的数据在特定条件下才打印出来

    通过设置字段的 PrintWhenExpression ,我们可以限定只有在某些特定的条件下字段值才会被打印出来,在PrintWhenExpression 中需要设置Boolean 型的表达式,如:new java.lang.Boolean($F{type}.trim().equals("mod_cook"))


六、嵌套子报表

1、在面板属性中找到 Subreport ,然后拖进你要放入的地方,放开鼠标后,会有一个新建报表。新建完报表之后会有个名为SUBREPORT_DIR 的Parameter,string类型,他会有个默认路径,指的是子报表的路径。由于子报表往往有多条数据,故最好单独放在一个detail中(例如:查询出来有多条数据,那么会循环显示在detail中)。

2、如果子报表中需要传入数据,那么就先点中子报表,然后在属性栏(不是参数里)中找到“ parameters ”,新建一个,例如:

     name为abz050  , Expression 为$F{ABZ050},因为这里的值是父报表查询的出来之后的值,所以不是用Parameter,而是Field。

3、在子报表中引用值,首先在子报表中定义一个变量 Parameter ,然后引用即可。

那为什么能找到呢?

因为:你在创建子报表的时候,也会自动创建一个 Parameter ,名称默认为 SUBREPORT_DIR ,它里面有个默认路径(新传入的路径会覆盖该默认路径)。

同时,可以点中子报表查看他的属性,里面有个 Subreport Exception 的值为 $P{SUBREPORT_DIR} + "子报表名称.jasper" ,这样系统就能找到了。当然系统还会自动配置一些其他子报表属性,具体的自己新建一个看看吧。


七、自动换行

    如果不处理一下,有些字段的内容太长了就会显示不全。选中该字段,右击 -> 属性,在 Text Field Stretch with overflow 勾上。

    同时把该行所有的字段选上,右击 -> 属性,在 Common Stretch Type 选择 Relative to tallest object。


八、内嵌函数的使用

举例:($F{ABB617}).toString()).substring(0,4)+"年"          把ABB617(Date类型)先转化成String然后截取年

ireport中使用内嵌函数只要在字段上看看他有哪些方法,然后直接使用即可。


九、高度根据内容自动变高

1、选中主键,在属性中找到 Stretch With Overflow 并选中。并把他单独放在一个 Detial或者其他 里面即可。
2、还有一个属性叫
Stretch type ,默认的值是No Stretch,可以改成Relative To Band Height。

第二个步骤我个人认为可做可不做。

     当然第二个步骤的功能在做表格的时候很有用,例如:表格是2列,那么两边的数据肯定不一样,或者是左边就是静态的,那么如果不选择这个属性,你就会发现,右边的数据很多的时候会扩充,但是左边不会,这个时候,我们就可以设置该属性,并把它们放到一个单独Detial或者其他容器中,那样 左右两边 就会等高了

 


十、设置共几页,第几页

$V{PAGE_NUMBER} 表示当前是第几页 ,在text field 的 选项evaluation time选report是共几页,now表是当前页。页码可在ireport里直接设置。  “共几页 第几页”

我是写在page footer 中。

分享到:
评论

相关推荐

    ireport的使用总结

    ### iReport 使用总结与关键技术点解析 #### 一、iReport 概述 iReport 是一款功能强大的报表设计工具,广泛应用于 Java 开发环境中。它能够帮助开发者轻松地设计并生成各种格式的报表,包括 PDF 和 Excel 等。...

    Jasperreports+Ireport的使用总结

    ** JasperReports + iReport 使用总结** JasperReports 和 iReport 是两个在 Java 开发中用于创建和设计报表的重要工具。JasperReports 是一个开源的报表库,它允许开发者生成静态和交互式的 PDF、HTML、Excel、CSV...

    iReport使用教程[转]+总结+模版

    【标题】"iReport使用教程[转]+总结+模版" 在IT行业中,报表设计是不可或缺的一部分,尤其在企业级应用中,数据的可视化呈现对于决策者至关重要。iReport是一款强大的开源报表设计工具,它是JasperReports库的一...

    iReport总结(吐血推荐)

    IReport的多栏使用,IReport中的如何使用变量进行合计,iReport使用JavaBean做数据源 ,如何取得ireport报表当前页及总页数,更多内容...

    ireport使用

    【ireport使用】 iReport是一款基于Java的开源报表设计工具,它是JasperReports库的一部分,主要用于设计复杂的PDF、HTML、Excel、CSV等格式的报表。本文将详细介绍iReport 4.5.1版本的使用方法。 1. **报表设计器...

    iReport使用JavaBean做数据源

    总结来说,通过iReport使用JavaBean作为数据源,开发者可以灵活地利用业务对象的数据,实现报表的动态生成,特别是在复杂的数据处理和跨系统数据共享的场景下,这种方法显得尤为实用。同时,这也使得报表设计与...

    iReport使用教程

    总结起来,这个 iReport 使用教程介绍了如何使用 iReport 设计一个基于 XML 数据源的表格报表。关键步骤包括创建模板、添加数据源、创建子报表、配置 XPath 查询、数据绑定以及样式调整。通过这个过程,我们可以了解...

    ireport 技术总结

    【ireport 技术总结】 ireport 是 JasperReports 的一个设计工具,用于创建复杂的报表布局。JasperReport 是一个开源的 Java 报表库,它允许开发者生成 PDF、HTML、Excel、CSV 和其他格式的报表。ireport 提供了一...

    Ireport3.7.6总结

    Ireport3.7.6完美文档详细说明

    ireport控制分页显示

    在示例中,使用`new Boolean($V{countName}.intValue()%5==0)`作为打印条件,这意味着当$countName变量的值除以5余数为0时,页面断点会被打印出来,从而实现每页显示5条记录的效果。 #### 步骤三:优化报表布局 ...

    ireport使用教程

    总结,本教程旨在帮助初学者掌握IReport的基本操作,从安装配置到报表设计,再到复杂功能的应用。在实际工作中,根据具体需求灵活运用这些知识,可以创建出满足业务需求的高质量报表。希望这个教程能对你在报表设计...

    ireport使用subdataset主表和子数据集进行参数传递

    总结来说,通过在 iReport 中巧妙地使用 `subdataset` 和参数传递,我们可以创建动态、交互式的报表,使得用户可以根据需要筛选和查看数据。这在处理复杂报表结构和多层级数据时特别有用。记住,正确配置数据集、...

    Ireport开发经验总结

    【Ireport开发经验总结】 IReport是一款用于设计Java应用程序中JasperReports报表的工具,它提供了丰富的图形化界面,使得开发者能够方便地创建复杂的报表。本文主要分享在使用IReport时的一些开发经验和技巧,特别...

    Ireport中文学习手册

    总结来说,这份"Ireport中文学习手册"是学习和提升Ireport使用技能的宝贵资料,无论你是初学者还是已经有一定基础的用户,都能从中受益。它将帮助你理解和解决在使用Ireport设计中文报表时可能遇到的问题,提升报表...

    ireport使用手册_中文版

    总结来说,iReport使用手册是一本全面的指南,涵盖了报表设计的各个方面,无论是对初学者还是对有经验的开发者都有很高的参考价值。通过阅读和实践手册中的内容,用户可以掌握使用iReport进行报表设计的全过程,并...

    ireport中table使用javaBean数据源

    提供的资源中,`IReport报表table使用javaBean数据源总结.docx`可能包含了详细步骤和常见问题解答。`官方文档.pdf`可能提供了更深入的官方指南。`testPDF.rar`可能是一个测试用例,包含生成的PDF报表样本,用于验证...

    jasperreports-1.3.3与iReport1.3.3初级使用

    总结,JasperReports 1.3.3和iReport 1.3.3是企业级报表开发的基础工具,它们结合使用能够帮助开发者高效地创建美观、功能强大的报表。通过学习和实践,你可以掌握这些工具的核心功能,为你的项目增添更多价值。

Global site tag (gtag.js) - Google Analytics