我有这样的报告
01 jan 02 jan 03 jan ... total
user1 3 5 10 18
user2 5 6 9 20
.
.
.
total ? ? ? 38
我可以使用我的JSTL代码在末尾计算每行总数。我没有找到用'?'计算结束标记列总数的方法。
对于行总计我使用
<c:forEach var="colNames" items="${listOfRecords}">
<tr>
<td>${colNames.key}</td>
<c:set var="htotal" value="0" />
<c:forEach var="noOfTasks" items="${colNames.value}" varStatus="status">
<td>${noOfTasks.value}</td>
<c:set var="htotal" value="${htotal+noOfTasks.value}" />
</c:forEach>
<td class="foo">${htotal}</td>
</tr>
</c:foreach>
此处${listOfRecords}
为HashMap<String, HashMap<String, Integer>>
。
我怎样才能做到这一点?
答案 0 :(得分:3)
这就是我能想到的所有内容:
<jsp:useBean id="column_totals" class="java.util.LinkedHashMap" scope="page"/>
<c:forEach var="row" items="${listOfRecords}">
<tr>
<td>${row.key}</td>
<c:set var="row_total" value="0"/>
<c:forEach var="column" items="${row.value}">
<td>${column.value}</td>
<c:if test="${empty column_totals[column.key]}">
<c:set target="${column_totals}" property="${column.key}" value="0"/>
</c:if>
<c:set target="${column_totals}" property="${column.key}" value="${column_totals[column.key] + column.value}"/>
<c:set var="row_total" value="${row_total + column.value}" />
</c:forEach>
<td class="foo">${row_total}</td>
</tr>
</c:foreach>
<tr>
<td>total</td>
<c:forEach var="column_total" items="${column_totals}">
<td>${column_total.value}</td>
</c:forEach>
</tr>
不得不改变一些名字因为我无法理解你的抱歉。
我认为它应该有用。