Java生成PDF报表文件

视频出处:https://www.bilibili.com/video/BV1Bo4y117zV?p=254

资源文件:链接:https://pan.baidu.com/s/1YpIeyK-j6NTZYf0pQkBpVA

提取码:2333

在企业开发中,除了常见的Excel形式报表,还有PDF形式的报表。那么如何导出PDF形式的报表呢?

1.iText简介

iText是著名的开放源码的站点sourceforge一个项目,是用于生成PDF文档的一个java类库。通过iText不仅可以生成PDF或rtf的文档,而且可以将XML、Html文件转化为PDF文件。

获取iText:

①下载iText.jar文件后,只需要在系统的CLASSPATH中加入iText.jar的路径,在程序中就可以使用iText类库了。

②引入maven坐标来使用iText:

<dependency><groupId>com.lowagie</groupId><artifactId>itext</artifactId><version>2.1.7</version>
</dependency>

示例代码:

package com.tsccg;import com.lowagie.text.Document;
import com.lowagie.text.DocumentException;
import com.lowagie.text.Paragraph;
import com.lowagie.text.pdf.PdfWriter;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;public class ItextDemo {public static void main(String[] args) {try {Document document = new Document();PdfWriter.getInstance(document, new FileOutputStream("D:\\Temp\\iTextTest.pdf"));document.open();document.add(new Paragraph("hello itext"));document.close();} catch (FileNotFoundException | DocumentException e) {e.printStackTrace();}}
}

iText是一种比较原生的API,当要生成的PDF内容较复杂时,使用起来会很繁琐。好比jdbc。

如此,便催生了第二种使用起来更为简便的技术:JasperReports

2.JasperReports

2.1JasperReports简介

JasperReports底层基于iText。

JasperReports是一个强大、灵活的报表生成工具,能够展示丰富的页面内容,并将之转换成PDF,HTML,或者XML格式。

该库完全由Java写成,可以用于在各种Java应用程序,包括J2EE,Web应用程序中生成动态内容。

一般情况下,JasperReports会结合Jaspersoft Studio(模板设计器)使用导出PDF报表。

maven坐标:

<dependency><groupId>net.sf.jasperreports</groupId><artifactId>jasperreports</artifactId><version>6.8.0</version>
</dependency>

2.2入门案例

第一步:创建maven工程,导入JasperReports的maven坐标

<dependency><groupId>net.sf.jasperreports</groupId><artifactId>jasperreports</artifactId><version>6.10.0</version><exclusions><exclusion><groupId>com.lowagie</groupId><artifactId>itext</artifactId></exclusion></exclusions>
</dependency>
<dependency><groupId>com.lowagie</groupId><artifactId>itext</artifactId><version>2.1.7</version>
</dependency>
<dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version>
</dependency>

第二步:将提前准备好的jrxml文件复制到maven工程中(后面会详细讲解如何用工具创建jrxml文件)

demo.jrxml:

<?xml version="1.0" encoding="UTF-8"?>
<!-- Created with Jaspersoft Studio version 6.9.0.final using JasperReports Library version 6.9.0-cb8f9004be492ccc537180b49c026951f4220bf3  -->
<jasperReport xmlns="http://jasperreports.sourceforge.net/jasperreports" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://jasperreports.sourceforge.net/jasperreports http://jasperreports.sourceforge.net/xsd/jasperreport.xsd" name="demo" pageWidth="595" pageHeight="842" columnWidth="555" leftMargin="20" rightMargin="20" topMargin="20" bottomMargin="20" uuid="e3403475-74c8-4358-a0fa-fb5b703b1abe"><property name="com.jaspersoft.studio.data.defaultdataadapter" value="One Empty Record"/><parameter name="company" class="java.lang.String"/><parameter name="reportDate" class="java.lang.String"/><queryString><![CDATA[]]></queryString><field name="name" class="java.lang.String"/><field name="address" class="java.lang.String"/><field name="email" class="java.lang.String"/><background><band splitType="Stretch"/></background><title><band height="90" splitType="Stretch"><image><reportElement x="0" y="0" width="100" height="86" uuid="1696c855-f322-478c-aecb-12aab31c1743"/><imageExpression><![CDATA["https://gimg2.baidu.com/image_search/src=http%3A%2F%2Fku.90sjimg.com%2Felement_pic%2F00%2F16%2F03%2F7956aed15300f1a.jpg&refer=http%3A%2F%2Fku.90sjimg.com&app=2002&size=f9999,10000&q=a80&n=0&g=0n&fmt=jpeg?sec=1640964989&t=aa09b2b82b9179dfb00664b1224c37e1"]]></imageExpression></image><staticText><reportElement x="210" y="20" width="200" height="40" uuid="2e246083-05c6-4dbd-9059-f7fe986d139e"/><textElement><font fontName="华文宋体" size="20"/></textElement><text><![CDATA[JasperReports Test]]></text></staticText><textField><reportElement x="468" y="50" width="100" height="30" uuid="14ac6dd3-7c52-457e-95b5-b8c2eebaae1b"/><textFieldExpression><![CDATA[$P{reportDate}]]></textFieldExpression></textField></band></title><detail><band height="37" splitType="Stretch"><textField><reportElement x="60" y="4" width="100" height="30" uuid="9fd8ea6a-722d-4c35-a4dc-74f3ed490709"/><textFieldExpression><![CDATA[$F{name}]]></textFieldExpression></textField><textField><reportElement x="227" y="4" width="100" height="30" uuid="d2926cd3-c477-4801-98a6-8d9d7f43adec"/><textFieldExpression><![CDATA[$F{address}]]></textFieldExpression></textField><textField><reportElement x="400" y="4" width="100" height="30" uuid="e7a64e8c-7c91-4c3a-9e1f-f9861353fd79"/><textFieldExpression><![CDATA[$F{email}]]></textFieldExpression></textField></band></detail><pageFooter><band height="37" splitType="Stretch"><textField><reportElement x="230" y="5" width="100" height="30" uuid="0eaaff53-787f-4d02-a940-4fd8f249ad95"/><textElement textAlignment="Center"/><textFieldExpression><![CDATA[$P{company}]]></textFieldExpression></textField></band></pageFooter>
</jasperReport>

第三步:编写测试方法,输出PDF报表

@Test
public void testJasperReports()throws Exception{//要导入的jrxml模板文件路径String jrxmlPath ="D:\\code\\自动生成报表\\01-生成PDF\\Project\\pdf-demo\\02-jasperReports-demo\\src\\main\\resources\\demo.jrxml";//生成的jasper文件路径String jasperPath ="D:\\code\\自动生成报表\\01-生成PDF\\Project\\pdf-demo\\02-jasperReports-demo\\src\\main\\resources\\demo.jasper";//编译模板JasperCompileManager.compileReportToFile(jrxmlPath,jasperPath);//构造数据Map paramters = new HashMap();paramters.put("reportDate",new SimpleDateFormat("yyyy-MM-dd").format(new Date()));paramters.put("company","tsccg");List<Map> list = new ArrayList();Map map1 = new HashMap();map1.put("name","zhangsan");map1.put("address","Beijing");map1.put("email","zhangsan@qq.com");Map map2 = new HashMap();map2.put("name","lisi");map2.put("address","ShangHai");map2.put("email","lisi@qq.com");list.add(map1);list.add(map2);//填充数据JasperPrint jasperPrint = JasperFillManager.fillReport(jasperPath, paramters,new JRBeanCollectionDataSource(list));//输出文件String pdfPath = "D:\\Temp\\jasperReportsTest.pdf";JasperExportManager.exportReportToPdfFile(jasperPrint,pdfPath);
}

2.3原理

  • JRXML:报表填充模板,本质是一个xml文件
  • Jasper:由JRXML模板编译成的二进制文件,用于代码填充数据
  • Jrprint:当用数据填充完Jasper后生成的对象,用于输出报表
  • Exporter:报表输出的管理类,可以指定要输出的报表为何种格式
  • PDF/HTML/XML:报表形式

2.4开发流程

使用JasperReports导出pdf报表,开发流程如下:

  1. 制作报表模板
  2. 模板编译
  3. 构造数据
  4. 填充数据
  5. 输出文件

如果由我们自己编写报表模板文件会很繁琐,这时我们就要使用一款模板设计软件:Jaspersoft Studio,通过该软件可以很便捷地设计出模板文件。

3.模板设计器Jaspersoft Studio

Jaspersoft Studio是一个图形化的报表设计工具,可以非常方便的设计出PDF报表模板文件(其实就是一个xml文件),再结合JasperReports使用,就可以渲染出PDF文件。

下载地址:https://community.jaspersoft.com/community-download

下载完成后会得到如下安装文件:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9JDQi3kp-1638462581061)(D:\code\分布式\health-project\Source\医疗实战-动力健康\day12\笔记\img\2.png)]

直接双击安装即可。

3.1 Jaspersoft Studio面板介绍

3.2 创建工程和模板文件

打开Jaspersoft Studio工具,首先需要创建一个工程,创建过程如下:

创建完工程后,可以在工程上点击右键,创建模板文件:

可以看到创建处理的模板文件后缀为jrxml,从设计区面板可以看到如下效果:

可以看到整个文件是可视化的,分为几大区域(Title、Page Header、Column Header等),如果某些区域不需要也可以删除。

在面板左下角可以看到有三种视图方式:Design(设计模式)、Source(源码模式)、Preview(预览模式):

  • 通过Design视图可以看到模板的直观结构和样式
  • 通过Source视图可以看到文件xml源码
  • 通过Preview视图可以预览PDF文件输出后的效果

通过右侧Palette窗口可以看到常用的元素:

3.3 设计模板文件

3.3.1 增减Band

可以根据情况删除或者增加模板文件中的区域(称为Band),例如在Page Header区域上点击右键,选择删除菜单:

其中Detail区域可以添加多个,其他区域只能有一个。

3.3.2 将元素应用到模板中

3.3.2.1 Image元素

从右侧Palette面板中选择Image元素(图片元素),拖动到Title区域:

弹出如下对话框,有多种创建模式,选择URL模式,并在下面输入框中输入一个网络图片的连接地址:

可以选中图片元素,鼠标拖动调整位置,也可以通过鼠标调整图片的大小。

调整完成后,可以点击Preview进入预览视图,查看PDF输出效果:

点击Source进入源码视图,查看xml文件内容:

其实我们上面创建的demo1.jrxml模板文件,本质上就是一个xml文件,只不过我们不需要自己编写xml文件的内容,而是通过Jaspersoft Studio这个设计器软件进行可视化设计即可。

3.3.2.2 Static Text元素

Static Text元素就是静态文本元素,用于在PDF文件上展示静态文本信息:

双击Title面板中的Static Text元素,可以修改文本内容:

选中元素,也可以调整文本的字体和字号:

点击Preview进入预览视图,查看效果:

3.3.2.3 Current Date元素

Current Date元素用于在报表中输出当前系统日期,将改元素拖动到Title区域:

预览输出效果:

默认日期输出格式如上图所示,可以回到设计视图并选中元素,在Properties面板中的Text Field子标签中修改日期输出格式:

修改日期格式:

保存文件后重新预览:

3.3.3 动态数据填充

上面我们在PDF文件中展示的都是一些静态数据,那么如果需要动态展示一些数据应该如何实现呢?我们可以使用Outline面板中的Parameters和Fields来实现。

Parameters通常用来展示单个数据,Fields通常用来展示需要循环的列表数据。

3.3.3.1 Parameters

在Parameters上点击右键,创建一个Parameter参数:

可以在右侧的Properties面板中修改刚才创建的参数名称:

将刚才创建的Parameter参数拖动到面板中:

进入预览视图,查看效果:

由于模板中我们使用了Parameter动态元素,所以在预览之前需要为其动态赋值:

注意:由于我们是在Jaspersoft Studio软件中进行预览,所以需要通过上面的输入框动态为Parameter赋值,在后期项目使用时,需要我们在Java程序中动态为Parameter赋值进行数据填充。

3.3.3.2 Fields

使用Fields方式进行数据填充,既可以使用jdbc数据源方式也可以使用JavaBean数据源方式。

  • jdbc数据源数据填充

第一步:在Repository Explorer面板中,在Data Adapters点击右键,创建一个数据适配器

第二步:选择Database JDBC Connection

第三步:选择mysql数据库,并完善jdbc连接信息

为了能够在Jaspersoft Studio中预览到数据库中的数据,需要加入MySQL的驱动包

第四步:在Outline视图中,右键点击工程名,选择Database and Query菜单

第五步:在弹出的对话框中选择刚刚创建的JDBC数据库连接选项

第六步:在弹出对话框中Language选择sql,在右侧区域输入SQL语句并点击Read Fields按钮

可以看到通过点击上面的Read Fields按钮,已经读取到了t_setmeal表中的所有字段信息并展示在了下面,这些字段可以根据需要进行删除或者调整位置

第七步:在Outline视图中的Fields下可以看到t_setmeal表中相关字段信息,拖动某个字段到设计区的Detail区域并调整位置

可以看到,在拖动Fields到设计区时,同时会产生两个元素,一个是静态文本,一个是动态元素。静态文本相当于表格的表头,可以根据需要修改文本内容。最终设计完的效果如下:

第八步:使用Preview预览视图进行预览

通过上图可以看到,虽然列表数据展示出来了,但是展示的还存在问题。在每条数据遍历时表头也跟着遍历了一遍。这是怎么回事呢?这是由于我们设计的表头和动态Fields都在Detail区域。为了能够解决上面的问题,需要将表头放在Column Header区域,将动态Fields放在Detail区域。具体操作如下:

1、在Outline视图的Column Header点击右键创建出一个区域

2、将Detail下的静态文本拖动到Column Header下

拖动完成后如下:

3、调整静态文本在Column Header区域的位置,最终效果如下

4、预览查看效果

  • JavaBean数据源数据填充

第一步:复制上面的demo1.jrxml文件,名称改为demo2.jrxml

修改Report Name:

第二步:打开demo2.jrxml文件,将detail区域中的动态Fields元素删除

第三步:将Outline面板中Fields下的字段全部删除

第四步:清除JDBC数据源和相关SQL语句

第五步:在Fields处点击右键创建新的Field

创建完成后在Properties属性面板中修改Field的名称

第六步:将创建的Fields拖动到Detail区域并调整好位置

注意:使用此种JavaBean数据源数据填充方式,无法正常进行预览,因为这些动态Fields需要在Java程序中动态进行数据填充。

3.3.4添加边框

3.4 结合JasperReports输出报表

前面我们已经使用Jaspersoft Studio设计了两个模板文件:demo1.jrxml和demo2.jrxml。其中demo1.jrxml的动态列表数据是基于JDBC数据源方式进行数据填充,demo2.jrxml的动态列表数据是基于JavaBean数据源方式进行数据填充。本小节我们就结合JasperReports的Java API来完成pdf报表输出。

3.4.1 JDBC数据源方式填充数据

第一步:创建maven工程,导入相关maven坐标

<dependency><groupId>net.sf.jasperreports</groupId><artifactId>jasperreports</artifactId><version>6.10.0</version><exclusions><exclusion><groupId>com.lowagie</groupId><artifactId>itext</artifactId></exclusion></exclusions>
</dependency>
<dependency><groupId>com.lowagie</groupId><artifactId>itext</artifactId><version>2.1.7</version>
</dependency>
<dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version>
</dependency>
<dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.47</version>
</dependency>

第二步:将设计好的demo1.jrxml文件复制到当前工程的resources目录下

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-95n3ylAM-1638462581123)(D:\code\分布式\health-project\Source\医疗实战-动力健康\day12\笔记\img\65.png)]

第三步:编写单元测试

@Test
public void testReport_JDBC() throws Exception{Class.forName("com.mysql.jdbc.Driver");Connection connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/health", "root", "root");String jrxmlPath = "D:\\ideaProjects\\projects111\\jasperreports_test\\src\\main\\resources\\demo1.jrxml";String jasperPath = "D:\\ideaProjects\\projects111\\jasperreports_test\\src\\main\\resources\\demo1.jasper";//编译模板JasperCompileManager.compileReportToFile(jrxmlPath,jasperPath);//构造数据Map paramters = new HashMap();paramters.put("company","传智播客");//填充数据---使用JDBC数据源方式填充JasperPrint jasperPrint = JasperFillManager.fillReport(jasperPath, paramters, connection);//输出文件String pdfPath = "D:\\test.pdf";JasperExportManager.exportReportToPdfFile(jasperPrint,pdfPath);
}

通过上面的操作步骤可以输出pdf文件,但是中文的地方无法正常显示。这是因为JasperReports默认情况下对中文支持并不友好,需要我们自己进行修复。具体操作步骤如下:

1、在Jaspersoft Studio中打开demo1.jrxml文件,选中中文相关元素,统一将字体设置为“华文宋体”并将修改后的demo1.jrxml重新复制到maven工程中

2、将本章资源/解决中文无法显示问题目录下的文件复制到maven工程的resources目录中

按照上面步骤操作后重新执行单元测试导出PDF文件:

3.4.2 JavaBean数据源方式填充数据

第一步:为了能够避免中文无法显示问题,首先需要将demo2.jrxml文件相关元素字体改为“华文宋体”并将demo2.jrxml文件复制到maven工程的resources目录下

第二步:编写单元测试方法输出PDF文件

@Test
public void testReport_JavaBean() throws Exception{String jrxmlPath = "D:\\ideaProjects\\projects111\\jasperreports_test\\src\\main\\resources\\demo2.jrxml";String jasperPath = "D:\\ideaProjects\\projects111\\jasperreports_test\\src\\main\\resources\\demo2.jasper";//编译模板JasperCompileManager.compileReportToFile(jrxmlPath,jasperPath);//构造数据Map paramters = new HashMap();paramters.put("company","传智播客");List<Map> list = new ArrayList();Map map1 = new HashMap();map1.put("tName","入职体检套餐");map1.put("tCode","RZTJ");map1.put("tAge","18-60");map1.put("tPrice","500");Map map2 = new HashMap();map2.put("tName","阳光爸妈老年健康体检");map2.put("tCode","YGBM");map2.put("tAge","55-60");map2.put("tPrice","500");list.add(map1);list.add(map2);//填充数据---使用JavaBean数据源方式填充JasperPrint jasperPrint = JasperFillManager.fillReport(jasperPath, paramters, new JRBeanCollectionDataSource(list));//输出文件String pdfPath = "D:\\test.pdf";JasperExportManager.exportReportToPdfFile(jasperPrint,pdfPath);
}

查看输出效果:

Java生成PDF报表文件相关推荐

  1. iText报表Java_(例)Java生成PDF报表 iText

    // 导入IO库类 import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileO ...

  2. Java生成PDF文件(Itext篇)

    在企业的信息系统中,报表处理一直占比较重要的作用,iText是一种生成PDF报表的Java组件.通过在服务器端使用Jsp或JavaBean生成PDF报表,客户端采用超链接显示或下载得到生成的报表,这样 ...

  3. Java生成PDF文件,java面试题,java初级笔试题

    写在最前面,我总结出了很多互联网公司的面试题及答案,并整理成了文档,以及各种学习的进阶学习资料,免费分享给大家.扫码加微信好友进[程序员面试学习交流群],免费领取.也欢迎各位一起在群里探讨技术. 一. ...

  4. Java生成PDF文件_自用

    Java生成PDF文件 一.前言 前几天,做ASN条码收货模块,需要实现打印下载收货报表,经一番查找,选定iText--用于生成PDF文档的一个Java类库.废话不多说,进入正题. 二.iText简介 ...

  5. iText5实现Java生成PDF文件完整版,二维码

    iText5实现Java生成PDF文件完整版 vue 项目中分别使用 vue-pdf 插件和内嵌 iframe 实现 PDF 文件预览,缩放,旋转,下载,保存等功能 ? Vue打印文件(v-print ...

  6. # Java 生成pdf文件

    Java 生成pdf文件 引入依赖 <!-- https://mvnrepository.com/artifact/com.itextpdf/itextpdf --> <depend ...

  7. java 其他文件转pdf_java 其他文件转成pdf java生成pdf

    java生成pdf需要用到的包pd4ml.jar 下载地址:http://download.csdn.net/detail/yanning1314/7124741 package com.cular. ...

  8. java 生成pdf itext_使用Java组件itext 生成pdf介绍

    iText是一个能够快速产生PDF文件的Java类库.iText的java类对于那些要产生包含文本,表格,图形的只读文档是很有用的.它的类库尤其与java Servlet有很好的给合.使用iText与 ...

  9. Flying Saucer生成pdf报表

    使用Flying Saucer生成pdf报表: 1.首先看一下Flying Saucer的官方介绍: https://github.com/flyingsaucerproject/flyingsauc ...

最新文章

  1. 企业分布式微服务云SpringCloud SpringBoot mybatis (二)Spring Boot属性配置文件详解...
  2. Android中Service的启动方式及Activity与Service的通信方式
  3. session的简介
  4. NotificationManager滑动不退出_退出支付宝的相互宝大病互助计划居然需要8个步骤!...
  5. 【原】PSD图标素材的全自动切图方法,适用于IOS、安卓、web前端等领域
  6. Python文件操作小案例:交替合并两个记事本文件
  7. 一些在PHPStudy部署中出现的问题解决
  8. SpringBoot properties和yml的区别
  9. InstallShield 使用说明
  10. python pyhook_python使用pyHook.HookManager()返回来的event中,event.Time怎么转换成为datetime形式?...
  11. m序列自相关matlab代码,m序列的输出及其自相关序列
  12. Groundhog Chasing Death
  13. 计算机ppt翻页笔,ppt翻页笔怎么使用?
  14. Python进程池apply_async的callback函数不执行的解决方案
  15. MySQL-间隙锁-加锁规则
  16. HTML复选框--checkbox
  17. Android与鸿蒙系统安全(一)
  18. 基于java的搜索引擎的设计与实现
  19. 菲尼克斯电源 - QUINT-PS/1AC/24DC/20 - 2866776
  20. 【camera】【CMOS Sensor】感光芯片cmos sensor简单介绍

热门文章

  1. 学完大数据的运用,龙歌平
  2. 无限制使用ppt转pdf功能
  3. mac电脑循环次数多少算新_Mac电脑上的活动监视器如何使用
  4. validation engine
  5. nodejs在windows下安装后npm命令无法使用的解决方法
  6. 字节码插桩之Java Agent
  7. python打包pyc
  8. NOIP复赛真题讲解普及组2012-摆花
  9. 【NOIP2012普及组】摆花
  10. 万魔声学荣获2022年度声学楼年会“技术创新大奖”