分组
Map<String,List<OrderListVO>> listMap = list.stream().collect(Collectors.groupingBy(OrderListVO::getOrderId));
求对象集合中的某个字段的总和 (那个字段必须是int或double) 否则需要转换
Integer result = list.stream().collect(Collectors.summingInt(MyConfirmOrderVo::getPrice));
money = String.valueOf(voList.stream().mapToLong(MyConfirmOrderVo::getPrice).sum());
根据对象集合中的时间字段进行排序(降序) .reversed()这个去掉后是升序
List<AssetInOut> listSumOrder = listSum.stream().sorted(Comparator.comparing(AssetInOut::getUpdateTime).reversed()).collect(Collectors.toList());
过滤字段不为空或为null 并且金额大于0的数据
inList = list.stream().filter(Objects::nonNull).filter((e) -> Double.valueOf(e.getMoney()) > 0).collect(Collectors.toList());
过滤字段值大于0的数据
inList = inList.stream().filter((e) -> Integer.valueOf(e.getMoney()) > 0).collect(Collectors.toList());
去重复数据
List<String> list = orderDao.count(queryOrderInfoVO);
List<String> stringList = list.stream().distinct().collect(Collectors.toList());
//根据对象中的某个字段进行去重
List<OrderListVO> collect = orderList.stream().collect(Collectors.collectingAndThen(
Collectors.toCollection(() -> new TreeSet<>(
Comparator.comparing(p -> p.getOrderId()))), ArrayList::new));
//根据对象中的多个字段进行去重
ArrayList<ProjectInfoVo> collect = vo.stream().collect(Collectors.collectingAndThen(
Collectors.toCollection(() -> new TreeSet<>(
Comparator.comparing(p -> p.getProjectId()+";"+p.getMember()))), ArrayList::new));
获取集合中的数据并且得到总和
//销售总额
BigDecimal sumPirce = merchantSalesParkDTOList.stream().map(MerchantSalesParkDTO::getScenicSpotMerchantSales).reduce(BigDecimal.ZERO,BigDecimal::add);
两个集合 : 过滤A集合总存在的B集合数据
tourNormalGoodList.removeIf(tourNormalGood -> commoditySaleDTOList.stream().anyMatch(commoditySaleDTO -> commoditySaleDTO.getCommodityName().equals(tourNormalGood.getName())));
集合中根据某个字段排序 : stream排序可能排不准 :
list.sort(Comparator.comparing(SalesChangeMerchantDTO::getTime, Comparator.comparingDouble(Double::parseDouble).reversed()));
A,B两个对象集合中的A,B两个对象中某个字段值相同,需要把A集合中的A对象的其余字段值赋予B集合中B对象
//遍历set部门名称
departmentProjectDTOList.forEach(departmentProjectDTO -> {
//过滤出两个集合中部门id相同的数据
List<PressDepartment> pressDepartments = pressDepartmentList.stream().filter(pressDepartment -> (pressDepartment.getDepartmentId().equals(departmentProjectDTO.getDepartmentId()))).collect(Collectors.toList());
//不为空证明有相同的数据
if (!CollectionUtils.isEmpty(pressDepartments)){
departmentProjectDTO.setDepartmentName(pressDepartments.get(0).getDepartmentName());
}else{
//添加需要清除的部门id
departmentIds.add(departmentProjectDTO.getDepartmentId());
}
});