我使用JRXML模板和动态输入参数作为输入来生成高级JRXML。稍后,此JRXML由JasperServer进行处理。主要思想是让用户选择所需的任何列并对其进行自定义。

DynamicJasper提供了用于构建自定义列的良好API,但是我遇到了复合列的问题。

例如,用户希望其列“ A”的计算公式为:

$F{INSTRUMENT} + " (" + $F{SECURITY_IDENTIFIER} + ")"


要么

$F{QUANTITY} == null ?0:$F{QUANTITY}.setScale(2, RoundingMode.HALF_UP)


因此,在进行输出之后,JRXML将在其details / band标签下包含记录,如下所示:

<textField isStretchWithOverflow="true">
    <reportElement key="DK_Instrument" x="0" y="0" width="184" height="12">
    </reportElement>
    <textElement/>
    <textFieldExpression><![CDATA[$F{INSTRUMENT} + " (" + $F{SECURITY_IDENTIFIER} + ")"]]></textFieldExpression>
</textField>
<textField isStretchWithOverflow="true">
    <reportElement key="DK_Quantity" x="220" y="0" width="56" height="12">
    </reportElement>
    <textElement/>
    <textFieldExpression><![CDATA[$F{QUANTITY} == null ?0:$F{QUANTITY}.setScale(2, RoundingMode.HALF_UP)]]></textFieldExpression>
</textField>


DynamicJasper中的AbstractColumn具有以下方法:

setColumnProperty(fieldName, className)
setCustomExpression(CustomExpression)
setCustomExpressionForCalculation(CustomExpression)


但它们都不适合我。

当DynamicJasper生成JasperReport时,它将尝试将那些字符串与现有字段进行匹配,并且由于字符串包含复合项,因此此时将失败。

任何想法/建议都很好。

最佳答案

您可以为此使用JRDesignTextFieldJRDesignExpression类。

JRDesignTextField textField = new JRDesignTextField();
JRDesignExpression expression = new JRDesignExpression();
expression.setText("$F{INSTRUMENT} + \"( \" + $F{SECURITY_IDENTIFIER} +\" ) \"");
//or expression.setText("$F{QUANTITY} == null ?0:$F{QUANTITY}.setScale(2, RoundingMode.HALF_UP)");
textField.setExpression(expression);


我认为这会对您有所帮助。
检查语法,我没有运行代码,但是它将给您想法。

08-07 13:59