如果我理解这个问题,你不能在主报告中总结子报告返回的金额,我有同样的问题,我以这种方式解决了。
1.- 创建一个从net.sf.jasperreports.engine.JRDefaultScriptlet扩展的类。并覆盖方法beforeReportInit()
这是这个类的代码。
package com.mem.utils;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import net.sf.jasperreports.engine.JRDefaultScriptlet;
public class SumarizacionSubtotales extends JRDefaultScriptlet {
private final Log log = LogFactory.getLog(getClass());
private Double total;
public Double getTotal() {
return total;
}
public Double add(Double cantidad) {
if(log.isDebugEnabled())log.debug("AGREGANDO LA CANTIDAD : " + cantidad);
this.total += cantidad;
return cantidad;
}
@Override
public void beforeReportInit() throws JRScriptletException {
if(log.isDebugEnabled())log.debug("beforeReportInit");
total = 0.0D;
}
}
2.- 在 ireport 的类路径中添加项目的 jar。
data:image/s3,"s3://crabby-images/e4381/e4381e11d2c2b5657d532649cf554ef2c752f436" alt="ireport 类路径配置。"
3.- 替换 REPORT scriptlet 的类。
data:image/s3,"s3://crabby-images/e3899/e3899eac3443b19779009d5435f6e546776de6ff" alt="默认报告脚本"
在您的班级的属性中。
data:image/s3,"s3://crabby-images/03408/03408498714a92d43160c6a454b6b4b974771a57" alt="你的班"
3.- 在要打印子报告返回值的组页脚中添加一个具有以下表达式的文本字段。
$P{REPORT_SCRIPTLET}.add( $V{sum_detalles} )
在这种情况下,$V{sum_detalles}是主报表中的一个变量,其中包含子报表返回的值。
4.- 在最后一页页脚中添加另一个具有以下表达式的文本字段。
$P{REPORT_SCRIPTLET}.getTotal()
data:image/s3,"s3://crabby-images/c3e67/c3e6737bb50290b3f672a5fbd7525584f19a8ded" alt="报告结构"