我使用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时,它将尝试将那些字符串与现有字段进行匹配,并且由于字符串包含复合项,因此此时将失败。
任何想法/建议都很好。
最佳答案
您可以为此使用JRDesignTextField和JRDesignExpression类。
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);
我认为这会对您有所帮助。
检查语法,我没有运行代码,但是它将给您想法。