public Map<String, Integer> formReportPosition(String formKey) { List<FormReportVO.Position> reportPositions = formDashboardMapper.selectFormReportPosition(formKey); return reportPositions.stream() .filter(item -> ObjectUtil.isNotNull(CollectionUtil.get(StrUtil.split(item.getSubmitAddress(), CharUtil.DASHED), 0))) .map(item -> { item.setSubmitProvince(CollectionUtil.get(StrUtil.split(item.getSubmitAddress(), CharUtil.DASHED), 0)); return item; }).collect(Collectors.groupingBy(FormReportVO.Position::getSubmitProvince, Collectors.summingInt(FormReportVO.Position::getCount))); }
时间: 2024-04-28 08:23:07 浏览: 91
这段代码实现了一个表单数据报表的功能,返回一个包含各个省份提交表单数量的 Map。具体实现如下:
1. 首先通过 `formDashboardMapper.selectFormReportPosition(formKey)` 方法获取表单报表数据,得到一个 `List<FormReportVO.Position>` 类型的对象 `reportPositions`。
2. 对 `reportPositions` 进行流式处理,使用 `filter()` 方法过滤掉 `submitAddress` 为空的数据。
3. 使用 `map()` 方法处理每个元素,将 `submitAddress` 字段按照 `-` 分割后取第一个元素作为省份,并将其设置到 `submitProvince` 字段中。
4. 最后使用 `collect()` 方法将处理后的数据按照省份分组,并将每个省份对应的表单数量相加,得到一个 Map 类型的结果。
其中,`Collectors.groupingBy()` 方法用于按照指定字段分组,`Collectors.summingInt()` 方法用于对每个组的指定字段进行求和。
阅读全文