jasperReport+ireport制作pdf报表教程

一.简介:
JasperReport是一个开源的java报表制作引擎,ireport是jasperReport的一个GUI工具。我们先使用ireport制作报表的样式,ireport会给我们产生个后缀名为jrxml的文件,然后我们通过java代码向这个模版填充数据,再然后显示出来,它支持输出的文件格式包括PDF,HTML,XHTML,EXCEL等等…一个典型的jrxml文件会包含以下元素:
<Title>: 每个报表一般会有一个名字.
<pageHeader>: 报表的公共要素, 比如页码,创建时间,创建人等信息一般放置在这里.
<columnHeader>: 放列的名称.
<detail>: 放置需要循环输出的数据.
<columnFooter>: 列级别的统计计算值或是列的说明.
<pageFooter>: 放置页级别的统计值或是页的说明.
<lastPageFooter>: 最后一页特殊的格式, 可以放置总结.
<summary>: 只在最后一页才出现.
二.案例:
jasperReport支持多种数据源,下面使用javaBean作为数据源讲解一个简单的例子。
  1. java代码
/**
 * 部门实体
 * @author Hewei
 *
 */
public class Department {
	
	private String name; //部门名称
	private List<Staff> staffs;  //员工集合
	
	public Department(){}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public List<Staff> getStaffs() {
		return staffs;
	}

	public void setStaffs(List<Staff> staffs) {
		this.staffs = staffs;
	}
}
/**
 * 员工实体
 * @author Hewei
 *
 */
public class Staff {

	private String name; //姓名
	private String sex;//性别

	public Staff(){}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public String getSex() {
		return sex;
	}

	public void setSex(String sex) {
		this.sex = sex;
	}
}


现在我们已经有个两个存在依赖关系的实体对象,我们要做的就是在一张pdf报表上显示部门名极其以下的员工的信息。 我们还需要一个静态方法向部门实体填充数据,如下…


/**
 * 数据工厂
 * @author HEWEI
 *
 */
public class Factory {
	/**
	 * 
	 * @return
	 */
	public static List<Department> returnData(){
		
		Staff staff1 = new Staff();
		staff1.setName("关羽");
		staff1.setSex("男");
		Staff staff2 = new Staff();
		staff2.setName("张飞");
		staff2.setSex("shit");
		Staff staff3 = new Staff();
		staff3.setName("刘备");
		staff3.setSex("男");
		
		List<Department> departments = new ArrayList<Department>();
		Department department = new Department();
		department.setName("研发部");
		List<Staff> staffs = new ArrayList<Staff>();
		staffs.add(staff1);
		staffs.add(staff2);
		staffs.add(staff3);
		departments.add(department);
		return departments;
	}
}


           然后我们用javabean 作为报表数据源,我觉得这样是符合mvc规范的,
    然而使用sql 查的话,  很麻烦, 要是遇到了 需要 几十张表数据的报表 , 
  写sql 很难实现。
      详细在附件中

猜你喜欢

转载自hewei5894.iteye.com/blog/1744757