带有多个子报表的Jasper报表

时间:2019-03-19 11:19:22

标签: java jasper-reports subreport

im是jasper report中的新增功能,并且im创建了一个将程序导出为pdf文件的java程序,并且im将jasper report与多个子报表一起使用, 我用jaspersoft studio创建了jrxml文件。

这是我的主报告jrxml文件的子报告部分

        <subreport>
            <reportElement positionType="Float" x="18" y="1" width="522" height="65" uuid="f3063ed3-775f-47df-8306-a939aecc9d89"/>
            <connectionExpression><![CDATA[$P{REPORT_CONNECTION}]]></connectionExpression>
            <subreportExpression><![CDATA["ClaimHistory.jasper"]]></subreportExpression>
        </subreport>

和另一个子报表部分

        <subreport>
            <reportElement positionType="Float" x="18" y="2" width="522" height="65" uuid="a70d75e0-b9d0-4f52-bb84-090993c2e90b"/>
            <connectionExpression><![CDATA[$P{REPORT_CONNECTION}]]></connectionExpression>
            <subreportExpression><![CDATA["ClaimDetail.jasper"]]></subreportExpression>
        </subreport>

每个子报表都使用JRBeanCollectionDataSource(list)作为数据, 这就是我将碧玉导出为pdf文件的方式

    String jasperFile = "E:/jasper/jasperFile.jrxml";
    FileInputStream inputStream = new FileInputStream(jasperFile);
    JasperReport jasperReport = JasperCompileManager.compileReport(inputStream);
    List<JasperPrint> jasperPrintList = new ArrayList<JasperPrint>();
    JasperPrint print = JasperFillManager.fillReport(jasperReport, params, new JREmptyDataSource());
    jasperPrintList.add(print);
    JRPdfExporter exporter = new JRPdfExporter();
    exporter.setExporterInput(SimpleExporterInput.getInstance(jasperPrintList)); //Set as export input my list with JasperPrint s
    exporter.setExporterOutput(new SimpleOutputStreamExporterOutput("E:/output.pdf")); //or any other out streaam
    exporter.exportReport();

我当前的技能仅能够通过使用此JRBeanCollectionDataSource(list)作为数据源而无需使用子报表来制作pdf。 (数据打印成功)

有人可以告诉我如何制作带有多个子报表的pdf报告,主jrxml文件和子报表jrxml文件中应该包含什么内容,以及Java代码中应该包含什么内容?以及如何使用多个JRBeanCollectionDataSource(清单)?, 我唯一知道的是使用Map params = new HashMap();但是怎么办呢? 谢谢。 -对不起,我英语不好。

1 个答案:

答案 0 :(得分:0)

首先将子报表的数据源定义为主报表(main.jrxml)中的字段

<field name="claimHistoryDataSource" class="java.util.ArrayList">
    <fieldDescription><![CDATA[claimHistoryList}]]></fieldDescription>
</field>

<field name="claimDetailDataSource" class="java.util.ArrayList">
    <fieldDescription><![CDATA[claimDetailList}]]></fieldDescription>
</field>

claimHistoryListclaimDetailList是java类中定义的ArrayList,用作主报表的数据源。

然后使用dataSourceExpression

将其传递到子报表
<subreport>
    <reportElement positionType="Float" x="18" y="1" width="522" height="65" uuid="f3063ed3-775f-47df-8306-a939aecc9d89"/>
    <dataSourceExpression><![CDATA[new net.sf.jasperreports.engine.data.JRBeanCollectionDataSource($F{claimHistoryDataSource})]]></dataSourceExpression>
    <subreportExpression><![CDATA["ClaimHistory.jasper"]]></subreportExpression>
</subreport>

<subreport>
    <reportElement positionType="Float" x="18" y="1" width="522" height="65" uuid="f3063ed3-775f-47df-8306-a939aecc9d89"/>
    <dataSourceExpression><![CDATA[new net.sf.jasperreports.engine.data.JRBeanCollectionDataSource($F{claimDetailDataSource})]]></dataSourceExpression>
    <subreportExpression><![CDATA["ClaimDetail.jasper"]]></subreportExpression>
</subreport>