Java开源报表JasperReport、iReport4.5.1使用详解(三)

Java开源报表JasperReport、iReport4.5.1使用详解(三)

前面两节,我们介绍、并亲手制作了一个报表,

本节我们将介绍,导出成Html、Excel、Pdf、以及从Scriptlet获取数据。

一、导出成Html方式

①首先建立一个 web project

图1.1.1

②导入相应的jar包到工程里面

jasperreports-4.5.1\dist 下面所有jar包,共4个

jasperreports-4.5.1.jar

jasperreports-applet-4.5.1.jar

jasperreports-fonts-4.5.1.jar

jasperreports-javaflow-4.5.1.jar

然后是jasperreports-4.5.1-project\jasperreports-4.5.1\lib 下面 com开头的所有jar包

commons-beanutils-1.8.0.jar

commons-collections-2.1.1.jar

commons-digester-2.1.jar

commons-javaflow-20060411.jar

commons-logging-1.1.1.jar

③将我们第二节中生成的jasper 文件复制进我们的web目录下面

ireport\fonts\report1.jasper

④编写jsp测试页面:

图1.4.1

页面报错:

java.lang.NoClassDefFoundError: org/codehaus/groovy/control/CompilationFailedException

解决办法:导入lib下面的groovy-all-1.7.5.jar 包即可解决问题。

这个是html的页面。

二、导出成Pdf方式。

①建立generatePdf.jsp文件

运行

:8080/IreportTest/generatePdf.jsp

之后报错:

出现这个错误主要是因为:没有导入iTextAsian.jar、iTextAsianCmaps.jar

解决办法:

1.导入iTextAsian.jar、iTextAsianCmaps.jar 包

2.设置字体属性如下图所示:

图2.1

注意:如果使用的是自定义的字体,也就是自己安装的字体,则需要导入相应字体的jar包 本人使用的是simfang.jar。

图2.2

三、导出成Excel格式:

测试代码如下:

运行的时候报错:

这是因为没有导入所需要的jxl.jar包,这个包是用来处理Excel文件的。

同样可以在lib目录下面查找。再运行一次,可以发现,网站空间,已经生成了我们所需要的excel文件。

最后生成的excel文件如图:

图3.1

四、使用使用Scriptlet来填充报表。

①编写Scriptlet类,需要继承自JRDefaultScriptlet(net.sf.jasperreports.engine.JRDefaultScriptlet),

我们要制作的报表是,报表有个Text Field的值,是这个ScriptletDemo 里面返回的值。

②将此ScriptLetDemo 导出成jar文件

myeclipse的导出方式很简单,选择这个ScriptLetDemo.java

File–>Export–>Java–>Java\Jar file 选择保存路径即可。

为什么要导出成jar文件呢,香港虚拟主机,香港虚拟主机,因为我们的iReport需要这个jar文件。

③从iReport的组件面板中拖拉一个Text Field放入Detail中,

这个Text Filed 是表达式是:

((com.yaxing.excel.ScriptLetDemo)$P{REPORT_SCRIPTLET}).getResult()

前面括弧里面是ScriptletDemo 的路径,后面的REPORT 是默认的Scriptname,

如果我们的报表中有多个Script,则名字的规则是

<scriptlet name>_SCRIPTLET (.for example, scritplet1_SCRIPTLET)

预览下,即可:如图所示:Static Text 下面的值,即是我们程序中的值!

图4.1

文中有些代码不理解没关系,后文会有详细的介绍,只是先,我们熟悉下这个报表的使用方式、开发流程。

整个项目使用的jar如图:

本文出自 “幽灵柯南的技术blog” 博客,谢绝转载!

而其实你还爱着他,你一点也不好。

Java开源报表JasperReport、iReport4.5.1使用详解(三)

相关文章:

你感兴趣的文章:

标签云: