Ang*_*ons 10 java reporting jasper-reports
我在我的JSF应用程序中使用JasperReport和ireport来动态生成报告.这就是我想要实现的目标: -
我的结构(读作HashMap/ArrayList)包含需要传递给报表的数据,以便在报表中显示相同的数据.
我的报告已经包含一个数据源连接,我使用该连接从DB获取一些值并在报告中填充它.
我正在创建一个子报表,以便对于需要从代码传递的数据,我可以使用子报表并将此子报表嵌入主报表中.
我的问题是: - 1.我无法将集合(读作HashMap/ArrayList)传递给子报告,用我的代码中的数据填充它.
我绝对相信必须有整个集合传递给子报表,以填充它的一些方法,我也试过但是创建一个JavaBean数据源连接,同时创造它说缺少类路径条目的连接.
我不能在jar中捆绑各自的类并将jar放在classpath中,因为值在结构中不断变化,....
任何人都可以指导我如何创建/传递java bean数据源到报告,以便可以填充数据...
请指导......
更新部分: -
用于将参数传递到报告和生成报告的Java代码: -
public class TestDataSource
{
public static void main(String[] args)
{
try {
JasperDesign jasperDesign = JRXmlLoader.load("D:\\jasperReports\\subReportDataSource.jrxml");
JasperReport jasperReport =(JasperReport)JasperCompileManager.compileReport(jasperDesign);
Map<String,Object> parameters = new HashMap<String,Object>();
parameters.put ("Title",generateCollection());
JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, parameters, new JRBeanCollectionDataSource(generateCollection()));
JasperViewer.viewReport(jasperPrint);
}catch(Exception e)
{
e.printStackTrace();
}
}
public static ArrayList<PersonBean> generateCollection()
{
ArrayList<PersonBean> arrlist=new ArrayList<PersonBean>();
arrlist.add(new PersonBean("A", 20));
arrlist.add(new PersonBean("B",30));
arrlist.add(new PersonBean("C",40));
arrlist.add(new PersonBean("D",50));
arrlist.add(new PersonBean("E",40));
arrlist.add(new PersonBean("F",60));
return arrlist;
}
Run Code Online (Sandbox Code Playgroud)
}
现在我创建了一个新的报告(Report)..在里面我放了一个子报告(子报告)..将子报告数据源配置为新的net.sf.jasperreports.engine.data.JRBeanCollectionDataSource($ P {标题})
连接类型: - 使用数据源连接类型.
现在在我的子报告中,我只放置了两个静态字段作为名称和年龄.如何告诉我的报告/子报告打印作为正在传递的hashmap中的值的值.
如果您已经拥有DataSource,那么在填写报告时,您可以通过param Map传递List/Map.
Map<String, Object> param = new HashMap<String, Object>();
param.put("SUB_DATA_SOURCE", yourList);
JasperFillManager.fillReport(jasperReport, param,
new JRBeanCollectionDataSource(yourMainListHere));
Run Code Online (Sandbox Code Playgroud)
这样做你必须在MAIN报告中创建一个参数,其名称与您在param Map中设置的名称相同,并且还给它一个Type Class(在我的例子中为List).
您必须创建子报表元素并将连接类型设置为"使用数据源表达式"并在"数据源表达式"中设置:
new net.sf.jasperreports.engine.data.JRBeanCollectionDataSource($P{SUB_DATA_SOURCE})
Run Code Online (Sandbox Code Playgroud)