查看JasperReport的api可以知道,JasperReport给我们提供了丰富的数据源,其中BeanCollectionDataSource是一个比较常用的数据源。正如其名,BeanCollectionDataSource是把一个装满Bean对象的Collection作为数据源,在JasperReport的模版中定义的每一个Filed就相当于Bean对象的一个Filed。
下面是一个模版的定义,取名为report4.jrxml
<?xml version="1.0" encoding="UTF-8"?> <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="report4" language="groovy" columnCount="2" pageWidth="800" pageHeight="842" columnWidth="380" leftMargin="20" rightMargin="20" topMargin="20" bottomMargin="20"> <property name="ireport.zoom" value="1.0"/> <property name="ireport.x" value="0"/> <property name="ireport.y" value="0"/> <parameter name="title" class="java.lang.String"/> <field name="id" class="java.lang.Integer"/> <field name="name" class="java.lang.String"/> <background> <band splitType="Stretch"/> </background> <title> <band height="79" splitType="Stretch"> <textField> <reportElement x="62" y="19" width="630" height="29"/> <textElement textAlignment="Center" verticalAlignment="Middle"> <font size="16"/> </textElement> <textFieldExpression><![CDATA[$P{title}]]></textFieldExpression> </textField> </band> </title> <columnHeader> <band height="24" splitType="Stretch"> <staticText> <reportElement x="226" y="2" width="100" height="20"/> <textElement textAlignment="Center"> <font size="12" isBold="true"/> </textElement> <text><![CDATA[序号]]></text> </staticText> <staticText> <reportElement x="434" y="2" width="100" height="20"/> <textElement textAlignment="Center"> <font size="12" isBold="true"/> </textElement> <text><![CDATA[名称]]></text> </staticText> </band> </columnHeader> <detail> <band height="37" splitType="Stretch"> <textField> <reportElement x="226" y="11" width="100" height="20"/> <textElement textAlignment="Center" verticalAlignment="Middle"/> <textFieldExpression><![CDATA[$F{id}]]></textFieldExpression> </textField> <textField> <reportElement x="434" y="11" width="100" height="20"/> <textElement textAlignment="Center" verticalAlignment="Middle"/> <textFieldExpression><![CDATA[$F{name}]]></textFieldExpression> </textField> </band> </detail> </jasperReport>
下面是进行测试的主程序:
import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import net.sf.jasperreports.engine.JRDataSource; import net.sf.jasperreports.engine.JRException; import net.sf.jasperreports.engine.JasperCompileManager; import net.sf.jasperreports.engine.JasperExportManager; import net.sf.jasperreports.engine.JasperFillManager; import net.sf.jasperreports.engine.JasperPrint; import net.sf.jasperreports.engine.JasperReport; import net.sf.jasperreports.engine.data.JRBeanCollectionDataSource; public class Test3 { public static void main(String args[]) throws JRException { //用于传递参数的Map Map<String, Object> parameters = new HashMap<String, Object>(); parameters.put("title", "JasperReport使用BeanCollectionDataSource示例"); //用于建立BeanCollection数据源的Collection List<Product> beanCollection = new ArrayList<Product>(); for (int i=0; i<10; ) { Product p = new Product(); p.setId(++i); p.setName("商品_" + i); beanCollection.add(p); } JRDataSource dataSource = new JRBeanCollectionDataSource(beanCollection); //编译jrxml文件 JasperReport jasperReport = JasperCompileManager.compileReport("src/report4.jrxml"); //填充数据 JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, parameters, dataSource); //导出为html文件 JasperExportManager.exportReportToHtmlFile(jasperPrint, "test3_beanCollectionDataSource.html"); System.out.println("........................."); } }
Product.class
public class Product { private int id; private String name; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } }