JasperReport

在了解DynamicJasper之前不得不先了解一下jasperReport,jasperReport是基于Java的一个开源的报表工具,它使得你可以在Java环境下像其它的IDE中一样生成报表,它是当前Java开发者中最常用的报表工具。

简单来说,jasperReport是一个在Java程序中生成报表的工具,支持PDF、Html、Excel等格式。

官网:https://community.jaspersoft.com/

要使用JasperReport,你需要做几件事:

1、设计报表模板文件.jrxml

2、编译报表模板.jasper

3、给模板填充数据

4、导出报表成文件

我们看到,在填充数据之前我们需要设计一个报表的模板,并且把这个模板编译成.jasper文件,设计模板可以使用如IReport或者JasperSoft Studio等设计器来进行可视化设计。而后,我们的程序中会加载这个.jasper编译文件,并给他填充数据最后导出为报表文件。

但是我们可以轻易得发现这个过程存在很多不方便的地方,如:为了设计这个模板,我必须去学会如何使用设计器,增加了我的学习成本;编译好的模板,在程序中不方便修改结构,很多情况下我非常希望模板是动态设计、编译的而不是一个固化的编译文件。这些问题的存在,也就促使DynamicJasper这个东西产生了。

DynamicJasper

DynamicJasper中文直译为动态的Jasper,它的意义直接表明了它的存在是为了动态的创建Jasper。官网上介绍DynamicJasper的时候说:“它是一个为了隐藏jasperReport模板设计的复杂性而存在的API”。所以,引入DynamicJasper可以让你通过编写代码的方式来设计模板,从而达到动态创建的效果。

官网:http://dynamicjasper.com/

要使用DynamicJasper你只需要引入依赖:

<dependency>
<groupId>ar.com.fdvs</groupId>
<artifactId>DynamicJasper</artifactId>
<version>5.1.1</version>
</dependency>

上文中我们提到过,JasperReport在填充数据前需要设计和编译出模板,那么DynamicJasper的作用在于动态地创建模板,所以对于如何使用DynamicJasper我们大概可以猜测到做的事情:

1、构建一个DynamicJasper

2、将DynamicJasper转换成JasperReport

3、填充数据

4、导出文件

代码示例

根据上面罗列的4个步骤,我们从代码的角度看看如何使用它(文章最后会有完整的代码贴出):

1、构建一个DynamicJasper,我们这里通过一个FastReportBuilder来构建一个DynamicReport

FastReportBuilder builder = new FastReportBuilder();
builder.addColumn("ID", "id", Integer.class.getName(), 30)
.addColumn("NAME", "name", String.class.getName(), 30)
.addColumn("AGE", "age", Integer.class.getName(), 30)
.setTitle("DynamicReport测试")
DynamicReport dynamicReport = builder.build();

2、将DynamicReport转换成JasperReport

JasperReport jasperReport = DynamicJasperHelper.generateJasperReport(dynamicReport, new ClassicLayoutManager(), null);

3、填充数据,这里简单地通过模拟数据的方式创建了一个数据源,并填充到了jasperReport里面

// 模拟数据
List<Map<String, Object>> persons = new ArrayList<>();
for (int i = 0; i < 10; i++) {
Map<String, Object> person = new HashMap<>();
person.put("id", 1);
person.put("name", "lay");
person.put("age", 25);
persons.add(person);
}
// 创建数据源
JRDataSource jrDataSource = new JRBeanCollectionDataSource(persons);
// 填充数据
JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, null, jrDataSource);

4、导出文件,这里演示导出为Html文件,通过jasperPrint的输入流,输出到本地C盘目录下的testHtml.html输出流当中(注意:JasperReport不支持中文,所以如果你导出为PDF中文会不显示,你可以下载源代码增加中文字体并重新打包jar文件然后引入项目,本文不扩展讲解)。

// html
HtmlExporter htmlExporter = new HtmlExporter();
htmlExporter.setExporterInput(new SimpleExporterInput(jasperPrint));
htmlExporter.setExporterOutput(new SimpleHtmlExporterOutput(new FileOutputStream(new File("C://Users/admin/Desktop/testHtml.html"))));
htmlExporter.exportReport();

最终你会看到一个如图的报表文件:

完整代码

下面贴出了完整的代码,可以从main方法开始阅读,代码按照上面的步骤编写。

import ar.com.fdvs.dj.core.DynamicJasperHelper;
import ar.com.fdvs.dj.core.layout.ClassicLayoutManager;
import ar.com.fdvs.dj.domain.DynamicReport;
import ar.com.fdvs.dj.domain.Style;
import ar.com.fdvs.dj.domain.builders.FastReportBuilder;
import ar.com.fdvs.dj.domain.constants.Font;
import ar.com.fdvs.dj.domain.constants.HorizontalAlign;
import net.sf.jasperreports.engine.*;
import net.sf.jasperreports.engine.data.JRBeanCollectionDataSource;
import net.sf.jasperreports.engine.export.HtmlExporter;
import net.sf.jasperreports.engine.export.JRPdfExporter;
import net.sf.jasperreports.export.SimpleExporterInput;
import net.sf.jasperreports.export.SimpleHtmlExporterOutput;
import net.sf.jasperreports.export.SimpleOutputStreamExporterOutput; import java.io.File;
import java.io.FileOutputStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map; /**
* @author lay
* @date 2018/10/26 18:00
*/
public class DynamicReportTest { private DynamicReport dynamicReport; private JasperReport jasperReport; private JRDataSource jrDataSource; private JasperPrint jasperPrint; public static void main(String[] args) throws Exception {
new DynamicReportTest().buildDynamicReport()
.generateJasperReport()
.fillDataSource()
.export();
} /**
* 构建DynamicJasper
* @return
* @throws ClassNotFoundException
*/
public DynamicReportTest buildDynamicReport() throws ClassNotFoundException {
FastReportBuilder builder = new FastReportBuilder();
Style style = new Style();
style.setHorizontalAlign(HorizontalAlign.CENTER);
builder.addColumn("中文", "id", Integer.class.getName(), 30, style)
.addColumn("姓名", "name", String.class.getName(), 30, style)
.addColumn("年龄", "age", Integer.class.getName(), 30, style)
.setTitle("DynamicReport测试")
.setUseFullPageWidth(true)
.setPrintBackgroundOnOddRows(true);
dynamicReport = builder.build();
return this;
} /**
* 生成JasperReport
* @return
* @throws JRException
*/
public DynamicReportTest generateJasperReport() throws JRException {
jasperReport = DynamicJasperHelper.generateJasperReport(dynamicReport, new ClassicLayoutManager(), null);
return this;
} /**
* 填充数据源
* @return
* @throws Exception
*/
public DynamicReportTest fillDataSource() throws Exception {
// 模拟数据
List<Map<String, Object>> persons = new ArrayList<>();
for (int i = 0; i < 10; i++) {
Map<String, Object> person = new HashMap<>();
person.put("id", 1);
person.put("name", "张三");
person.put("age", 25);
persons.add(person);
}
// 创建数据源
jrDataSource = new JRBeanCollectionDataSource(persons);
// 填充数据
jasperPrint = JasperFillManager.fillReport(jasperReport, null, jrDataSource);
return this;
} /**
* 导出为Html文件
* @throws Exception
*/
public void export() throws Exception {
// html
HtmlExporter htmlExporter = new HtmlExporter();
htmlExporter.setExporterInput(new SimpleExporterInput(jasperPrint));
htmlExporter.setExporterOutput(new SimpleHtmlExporterOutput(new FileOutputStream(new File("C://Users/admin/Desktop/testHtml.html"))));
htmlExporter.exportReport();
}
}

补充说明

上面的示例只是为了演示而快速创建,如果需要更多自定义功能可以参考官方的Getting Started:http://dynamicjasper.com/documentation-examples/getting-started/

另外DynamicJasper还支持图表、交叉报表、子报表、Html等更多强大的功能,你可以参考How To来深入了解:http://dynamicjasper.com/documentation-examples/how-to-2/

DynamicJasper入门的更多相关文章

  1. Angular2入门系列教程7-HTTP(一)-使用Angular2自带的http进行网络请求

    上一篇:Angular2入门系列教程6-路由(二)-使用多层级路由并在在路由中传递复杂参数 感觉这篇不是很好写,因为涉及到网络请求,如果采用真实的网络请求,这个例子大家拿到手估计还要自己写一个web ...

  2. ABP入门系列(1)——学习Abp框架之实操演练

    作为.Net工地搬砖长工一名,一直致力于挖坑(Bug)填坑(Debug),但技术却不见长进.也曾热情于新技术的学习,憧憬过成为技术大拿.从前端到后端,从bootstrap到javascript,从py ...

  3. Oracle分析函数入门

    一.Oracle分析函数入门 分析函数是什么?分析函数是Oracle专门用于解决复杂报表统计需求的功能强大的函数,它可以在数据中进行分组然后计算基于组的某种统计值,并且每一组的每一行都可以返回一个统计 ...

  4. Angular2入门系列教程6-路由(二)-使用多层级路由并在在路由中传递复杂参数

    上一篇:Angular2入门系列教程5-路由(一)-使用简单的路由并在在路由中传递参数 之前介绍了简单的路由以及传参,这篇文章我们将要学习复杂一些的路由以及传递其他附加参数.一个好的路由系统可以使我们 ...

  5. Angular2入门系列教程5-路由(一)-使用简单的路由并在在路由中传递参数

    上一篇:Angular2入门系列教程-服务 上一篇文章我们将Angular2的数据服务分离出来,学习了Angular2的依赖注入,这篇文章我们将要学习Angualr2的路由 为了编写样式方便,我们这篇 ...

  6. Angular2入门系列教程4-服务

    上一篇文章 Angular2入门系列教程-多个组件,主从关系 在编程中,我们通常会将数据提供单独分离出来,以免在编写程序的过程中反复复制粘贴数据请求的代码 Angular2中提供了依赖注入的概念,使得 ...

  7. wepack+sass+vue 入门教程(三)

    十一.安装sass文件转换为css需要的相关依赖包 npm install --save-dev sass-loader style-loader css-loader loader的作用是辅助web ...

  8. wepack+sass+vue 入门教程(二)

    六.新建webpack配置文件 webpack.config.js 文件整体框架内容如下,后续会详细说明每个配置项的配置 webpack.config.js直接放在项目demo目录下 module.e ...

  9. wepack+sass+vue 入门教程(一)

    一.安装node.js node.js是基础,必须先安装.而且最新版的node.js,已经集成了npm. 下载地址 node安装,一路按默认即可. 二.全局安装webpack npm install ...

随机推荐

  1. jquery源码解析:val方法和valHooks对象详解

    这一课,我们将讲解val方法,以及对value属性的兼容性处理,jQuery中通过valHooks对象来处理. 首先,我们先来看下val方法的使用: $("#input1").va ...

  2. TPS和QPS定义以及影响TPS的因素

    一.TPS:Transactions Per Second(每秒传输的事物处理个数),即服务器每秒处理的事务数.TPS包括一条消息入和一条消息出,加上一次用户数据库访问.(业务TPS = CAPS × ...

  3. Python笔记之字典循环

    Python笔记之字典循环   1.问题 Python是一门比较好入门的编程语言,但是入门简单,当然坑也是有的,今天就来介绍一个我遇到的坑吧,也是很简单的一个,就是当时脑子有点转不过弯来了. 先看代码 ...

  4. leetcode-40-组合总和 II

    题目描述: 给定一个数组 candidates 和一个目标数 target ,找出 candidates 中所有可以使数字和为 target 的组合. candidates 中的每个数字在每个组合中只 ...

  5. 2016级算法期末上机-B.简单·ModricWang's Fight with DDLs I

    1124 ModricWang's Fight with DDLs I 思路 这道题本质上就是一个多项式求值,题目中的n需要手动算一下,单位复根可以根据复数的性质来求,即\(e^{i\pi}+1=0\ ...

  6. Java多线程——不变性与安全发布

    1.不变性 某个对象在被创建后其状态就不能被修改,那么这个对象就称为不可变对象,不可变对象一定是线程安全的.不可变对象很简单.他们只有一种状态,并且该状态由构造函数来控制. 当满足以下条件时,对象才是 ...

  7. opencv 将视频分解成图片和使用本地图片合成视频

    代码如下: // cvTest.cpp : Defines the entry point for the console application. #include "stdafx.h&q ...

  8. 前端知识总结--BFC

    Block Formatting Context,中文直译为块级格式上下文. 1. BFC的定义 是 W3C CSS 2.1 规范中的一个概念,它决定了元素如何对其内容进行定位,以及与其他元素的关系和 ...

  9. js时间转变

    1.转换为标准时间 var parserDate = function (date) { var t = Date.parse(date); if (!isNaN(t)) { return new D ...

  10. Unity 依赖注入

    关于Ioc的框架有很多,比如astle Windsor.Unity.Spring.NET.StructureMap,我们这边使用微软提供的Unity做示例,你可以使用Nuget添加Unity,也可以引 ...