一、從List<Staff>篩選符合條件的List<String>:app
List<Staff> staffListtemp=Lists.newArrayList(); List<String> staffIdList=staffListtemp.stream().filter(staff->deptIdSet.contains(staff.getDeptId())).map(staffId->staffId.getStaffId()).collect(Collectors.toList());
二、從List<PositionRealtime>轉爲Map<String,PositionRealtime>:ide
List<PositionRealtime> prList Map<String,PositionRealtime> prMap=prList.stream().collect(Collectors.toMap(PositionRealtime::getStaffId, PositionRealtime->PositionRealtime));
三、從Set<String>轉爲拼接後的String:code
Set<String> inPostStaffIds = Sets.newHashSet(); String inPostIds = inPostStaffIds.stream().reduce((a,b)->a+","+b).get();
四、從List<StaffGpsTimeDTO>經過StaffId做爲分組條件分組爲Map<String,List<StaffGpsTimeDTO>>對象:對象
List<StaffGpsTimeDTO> positionHistoryTimeList = positionHistoryManageDao.getPositionHistoryTimeList(filterPropertyMap2); for(StaffGpsTimeDTO staffGpsTimeDTO : positionHistoryTimeList){ List<Date> list = Lists.newArrayList(); if(gpsMap.get(staffGpsTimeDTO.getStaffId()) != null){ list = gpsMap.get(staffGpsTimeDTO.getStaffId()); } list.add(staffGpsTimeDTO.getGpsTime()); gpsMap.put(staffGpsTimeDTO.getStaffId(), list); } Map<string,List<>> aaa=positionHistoryTimeList.stream().collect(Collectors.groupingBy(StaffGpsTimeDTO::getStaffId,Collectors.mapping(StaffGpsTimeDTO::getGpsTime, Collectors.toList())));