場景說明
在使用Jasper+jaspersoftStudio導出用戶列表數(shù)據(jù)導出(如下圖)是比較簡單的,就是把用戶列表數(shù)據(jù),一個List集合放到 JRBeanCollectionDataSource中即可。
data:image/s3,"s3://crabby-images/a471f/a471f6ba9aedc3af7659d1f12c52f74a5e0adedb" alt="Jasper+jaspersoftStudio01"
但是如果有多個List集合需要導出呢,這個應該怎么辦?比如:一個用戶的集合List,還有一個統(tǒng)計報表(也需要一個List集合數(shù)據(jù))
data:image/s3,"s3://crabby-images/81549/815491acd23dfb37433ded6814e2e0781d0715bb" alt="Jasper+jaspersoftStudio02"
data:image/s3,"s3://crabby-images/054d0/054d093c5ef108aed7d7c8eb8b3a5f37bd19e665" alt="Jasper+jaspersoftStudio03"
實現(xiàn)思路
需要用到子數(shù)據(jù)集,如果多出幾個List,就創(chuàng)建多少個子數(shù)據(jù)集Dataset
·動手實現(xiàn)
·制作模板
第一步:新建一個Jasper Report模板,選擇 Blank A4 (A4紙大小的模板),然后 Next 命名為userList.jrxml.
data:image/s3,"s3://crabby-images/6ff43/6ff439766f3f6ef57bfaa4b158a7abde1c5cfd39" alt="Jasper+jaspersoftStudio04"
第二步:刪除無用的Band,只留 Title 、Colunn Header、Detail、Summary
data:image/s3,"s3://crabby-images/86e23/86e23905f1a2e9e208bbd309fb11b1bfd65f59b9" alt="Jasper+jaspersoftStudio04"
第三步:創(chuàng)建Filed和parameter
①、創(chuàng)建Filed,這幾個Field用來導出用戶列表的
data:image/s3,"s3://crabby-images/46db9/46db96326e051b30f547fd643ccf421ce1c609df" alt="Jasper+jaspersoftStudio06"
②、創(chuàng)建parameter,名稱是chartList,指定類型是ArrayList,這個參數(shù)是用來放圖表中所需數(shù)據(jù)的
data:image/s3,"s3://crabby-images/d12b2/d12b2304b05bce17efff1a390edab2d44f553d63" alt="Jasper+jaspersoftStudio07"
第四步:創(chuàng)建子數(shù)據(jù)集
data:image/s3,"s3://crabby-images/df378/df3780a0edf07df3fc4734615d4fd91236721d72" alt="Jasper+jaspersoftStudio08"
data:image/s3,"s3://crabby-images/27f35/27f35c712a2db44c3701ee67808078e07b13d7d7" alt="Jasper+jaspersoftStudio09"
data:image/s3,"s3://crabby-images/a2714/a2714b689e8db458a46e079dee5be77d66ce4a70" alt="Jasper+jaspersoftStudio10"
data:image/s3,"s3://crabby-images/27e2d/27e2d5ebade873856948eec3baed51aff83aa0c1" alt="Jasper+jaspersoftStudio11"
第五步:在模板上拖拽用戶列表數(shù)據(jù),注意指定中文名稱
data:image/s3,"s3://crabby-images/5df58/5df58267f3e0ffacbeec9b6b022224d0af24ae69" alt="Jasper+jaspersoftStudio12"
第六步:在模板上拖拽圖表
data:image/s3,"s3://crabby-images/dde67/dde6770dce334aa3773d2a71e065c0a026999c6d" alt="Jasper+jaspersoftStudio13"
data:image/s3,"s3://crabby-images/d715a/d715ad1db31ad0dad41164241eddda76d6303664" alt="Jasper+jaspersoftStudio14"
data:image/s3,"s3://crabby-images/c16f8/c16f8da1f222fcc0716735d92facbd211c9473bf" alt="Jasper+jaspersoftStudio15"
注意:我這里的是否顯示圖例改成了false,不然導出會失敗
data:image/s3,"s3://crabby-images/45c00/45c00df01a102d9c213dcd2d7ab3d8b4a949fa4b" alt="Jasper+jaspersoftStudio16"
代碼導出
準備兩個實體類:
用來導出用戶列表
package com.itheima.pojo;
import lombok.Data;
/**
* 員工
*/
@Data
public class People {
private Long id;
private String userName; //員工名
private String phone; //手機號
private String province; //省份名
private String hireDateStr; // 入職日期
public People(Long id, String userName, String phone, String province, String hireDateStr) {
this.id = id;
this.userName = userName;
this.phone = phone;
this.province = province;
this.hireDateStr = hireDateStr;
}
}
用來導出圖表
package com.itheima.pojo;
import lombok.Data;
@Data
public class PeopleCount {
private String provinceName; //省份名
private Integer count; //數(shù)量
public PeopleCount(String provinceName, Integer count) {
this.provinceName = provinceName;
this.count = count;
}
}
代碼實現(xiàn)PDF導出
package com.itheima.test;
import com.itheima.pojo.People;
import com.itheima.pojo.PeopleCount;
import net.sf.jasperreports.engine.JasperExportManager;
import net.sf.jasperreports.engine.JasperFillManager;
import net.sf.jasperreports.engine.JasperPrint;
import net.sf.jasperreports.engine.data.JRBeanCollectionDataSource;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.util.*;
public class PdfDemo {
public static void main(String[] args) throws Exception{
// 1、獲取模板文件
String templateFile = "d://userList.jasper";
// 2、準備數(shù)據(jù)
// 2.1 列表數(shù)據(jù)
JRBeanCollectionDataSource dataSource = new JRBeanCollectionDataSource(getListData());
// 2.2圖表數(shù)據(jù)
Map params = new HashMap();
params.put("chartList",getChartListData());
JasperPrint jasperPrint = JasperFillManager.fillReport(new FileInputStream(templateFile), params,dataSource);
JasperExportManager.exportReportToPdfStream(jasperPrint,new FileOutputStream("d://用戶列表數(shù)據(jù).pdf"));
}
public static List<People> getListData(){
List<People> peopleList = new ArrayList<>();
peopleList.add(new People(1L, "大一","13800000001","北京市","2001-01-01"));
peopleList.add(new People(2L, "不二","13800000002","河北省","2002-01-02"));
peopleList.add(new People(3L, "張三","13800000003","河北省","2003-03-03"));
peopleList.add(new People(4L, "李四","13800000004","河北省","2004-02-04"));
peopleList.add(new People(5L, "王五","13800000005","河北省","2005-03-05"));
peopleList.add(new People(6L, "趙六","13800000006","河北省","2006-04-06"));
peopleList.add(new People(7L, "沈七","13800000007","河北省","2007-06-07"));
peopleList.add(new People(8L, "酒八","13800000008","河北省","2008-07-08"));
peopleList.add(new People(9L, "第九","13800000009","山東省","2009-03-09"));
peopleList.add(new People(10L, "石十","13800000010","山東省","2010-07-10"));
peopleList.add(new People(11L, "肖十一","13800000011", "山東省","2011-12-11"));
peopleList.add(new People(12L, "星十二","13800000012", "山東省","2012-05-12"));
peopleList.add(new People(13L, "釵十三","13800000013", "山東省","2013-06-13"));
peopleList.add(new People(14L, "賈十四","13800000014", "山東省","2014-06-14"));
peopleList.add(new People(15L, "甄世武","13800000015", "山東省","2015-06-15"));
return peopleList;
}
public static List<PeopleCount> getChartListData(){
List<PeopleCount> peopleCountList = new ArrayList<>();
peopleCountList.add(new PeopleCount("北京市",100));
peopleCountList.add(new PeopleCount("河北省",200));
peopleCountList.add(new PeopleCount("山東省",220));
peopleCountList.add(new PeopleCount("河南省",230));
return peopleCountList;
}
}
效果如下:
data:image/s3,"s3://crabby-images/1705e/1705e614be1cd0c3f25aa6400bf568666d25f001" alt="Jasper+jaspersoftStudio17"
data:image/s3,"s3://crabby-images/a5deb/a5deb7f66a74c9a1b2bcccc70c6bdc31a8e52809" alt="Jasper+jaspersoftStudio18"
猜你喜歡
什么是枚舉?沒有枚舉之前,怎么做的?