gpt4 book ai didi

jasper-reports - 如何通过jrxml创建动态报告?

转载 作者:行者123 更新时间:2023-12-04 20:59:53 24 4
gpt4 key购买 nike

我正在使用 jrxml 创建动态报告。我已经参数化了列,即该报告的 jrxml 也可用于生成其他报告。

但是,我还没有设法使字段变得灵活。也就是说,如果用户选择 4 列它会起作用,但如果选择了 1 或 2 或 3 列,则会由于字段名称未识别而出现错误。

如果可以创建字段名称的默认表达式或可以使用 for 循环/java 脚本,请紧急发布解决方案。

此外,如何准确地使用 jasper 设计器来实现这一目标?

jrxml 如下:

<?xml version="1.0"?>
<!DOCTYPE jasperReport
PUBLIC "-//JasperReports//DTD Report Design//EN"
"http://jasperreports.sourceforge.net/dtds/jasperreport.dtd">
<jasperReport name="report1">
<parameter name="reportTitle" class="java.lang.String"/>
<parameter name="author" class="java.lang.String"/>
<parameter name="startDate" class="java.lang.String"/>

<parameter name="C1" class="java.lang.String">
<defaultValueExpression>
new java.lang.String("")
</defaultValueExpression>
</parameter>
<parameter name="C2" class="java.lang.String">
<defaultValueExpression>
new java.lang.String("")
</defaultValueExpression>
</parameter>
<parameter name="C3" class="java.lang.String">
<defaultValueExpression>
new java.lang.String("")
</defaultValueExpression>
</parameter>
<parameter name="C4" class="java.lang.String">
<defaultValueExpression>
new java.lang.String("default parameter value")
</defaultValueExpression>
</parameter>

<field name="COLUMN_1" class="java.lang.Integer"/>
<field name="COLUMN_2" class="java.lang.Integer"/>
<field name="COLUMN_3" class="java.lang.Integer"/>
<field name="COLUMN_4" class="java.lang.Integer"/>

<title>
<band height="60">
<textField>
<reportElement x="0" y="10" width="500" height="40"/>
<textElement textAlignment="Center">
<font size="24"/>
</textElement>
<textFieldExpression class="java.lang.String">
<![CDATA[$P{reportTitle}]]>
</textFieldExpression>
</textField>
<textField>
<reportElement x="0" y="40" width="500" height="20"/>
<textElement textAlignment="Center"/>
<textFieldExpression class="java.lang.String">
<![CDATA["Run by: " + $P{author}
+ " on " + $P{startDate}]]>
</textFieldExpression>
</textField>
</band>
</title>

<columnHeader>
<band height="30">
<rectangle>
<reportElement x="0" y="0" width="500" height="25"/>
<graphicElement/>
</rectangle>

<textField>
<reportElement x="0" y="5" width="170" height="15"/>
<textFieldExpression class="java.lang.String">
<![CDATA[$P{C1}]]>
</textFieldExpression>
</textField>

<textField>
<reportElement x="70" y="5" width="170" height="15"/>
<textFieldExpression class="java.lang.String">
<![CDATA[$P{C2}]]>
</textFieldExpression>
</textField>

<textField>
<reportElement x="150" y="5" width="150" height="15"/>
<textFieldExpression class="java.lang.String">
<![CDATA[$P{C3}]]>
</textFieldExpression>
</textField>

<textField>
<reportElement x="300" y="5" width="150" height="15"/>
<textFieldExpression class="java.lang.String">
<![CDATA[$P{C4}]]>
</textFieldExpression>
</textField>
</band>
</columnHeader>

<detail>
<band height="20">
<textField>
<reportElement x="5" y="0" width="50" height="15"/>
<textElement/>
<textFieldExpression class="java.lang.Integer">
<![CDATA[$F{COLUMN_1}]]>
</textFieldExpression>
</textField>

<textField>
<reportElement x="90" y="0" width="150" height="15"/>
<textElement/>
<textFieldExpression class="java.lang.Integer">
<![CDATA[$F{COLUMN_2}]]>
</textFieldExpression>
</textField>

<textField>
<reportElement x="170" y="0" width="50" height="15"/>
<textElement/>
<textFieldExpression class="java.lang.Integer">
<![CDATA[$F{COLUMN_3}]]>
</textFieldExpression>
</textField>

<textField>
<reportElement x="320" y="0" width="150" height="15"/>
<textElement/>
<textFieldExpression class="java.lang.Integer">
<![CDATA[$F{COLUMN_4}]]>
</textFieldExpression>
</textField>
</band>
</detail>
</jasperReport>

最佳答案

如果您希望它像隐藏/显示新字段一样是动态的,我认为唯一的方法是在运行时修改您的 jrxml 并编译它。

更新:

要在运行时使 JasperReport 动态化,您可以采用三种方法:

1.在iReport中创建JRXML
如果您的报表很复杂,并且有很多子报表和子数据集,最好采用这种方法,因为 iReport 将使您以后设计和维护起来更快更容易。
遵循此方法时,您将创建 jrxml 文件并将其存储在类路径中,在运行时您将加载、打开该文件并修改所需的 XML 标记。我建议从包含最大列数的 jrxml 开始,然后如果用户选择较少的列,则在 jrxml 中找到那些额外的列并删除它们。

2.用Java创建整个报告
如果您的报告非常简单,则这种方法会更好,例如快速表格报告,在这种情况下,您不需要 jrxml 文件,您可以使用 JasperReport 库 API 在运行时从头开始创建整个报告。这种方法将使设计报告变得更加困难,因为在编译和运行之前您将看不到任何内容。更糟糕的是,它是一个维护噩梦。
您最终的 Java 源代码将如下所示:"Fixed Column Width Test" 1

3.使用DynamicJasper
最后,如果您对新工具持开放态度,那么总是有 DynamicJasper ,您可以查看 online demo同样,它很酷。
最后我保留了 DJ 向您展示了所有方法,DJ 实际上使用了第二种方法。即时创建报告的 Java 源代码。

1:固定列宽测试报告版权属于DynamicJasper,这里仅作为示例使用。

关于jasper-reports - 如何通过jrxml创建动态报告?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1936068/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com