將list轉為map
Map<Long, ItemTO> itemMap = items.stream().collect(Collectors.toMap(ItemTO::getEventId, Function.identity(), (v1, v2)->v1));
- List中物件的某個屬性值拿出來作為一個list
// 去重
List<Long> ids = items.stream().map(ItemTO::getId).distinct().collect(Collectors.toList());
// 不去重
List<Long> ids = items.stream().map(ItemTO::getId).collect(Collectors.toList());
- 將list轉為Map<Long, List>
Map<Long, List<ItemTO>> itemListMap = itemList.stream().collect(Collectors.groupingBy(item -> item.getId()));
Map<Long, ItemTO> itemMap =
items.stream().collect(Collectors.toMap(ItemTO::getEventId, Function.identity(), (v1, v2)->v1));
- 將list中的string轉為long
List<Long> idList = groupList.stream().map(group->Long.parseLong(group.getGroupLeaderId())).collect(Collectors.toList());
- 過濾操作
groupIdList.stream().filter(x -> x!=null).collect(Collectors.toList());
List<Long> allPlatformIids = allStoreItemIndexResultTOS.stream().filter(t -> StoreItemTypeEnum.PLATFORM.getType()
.equals(t.getType())).map(StoreItemIndexResultTO::getIid).collect(Collectors.toList());
//過濾採購數量為0的sku
List<ObmSkuInfoTO> skuCollectList = skuInfoTOList.stream().
filter(e -> e.getNum() > 0).collect(Collectors.toList());
/**
* 在訂單列表中過濾指定的oid
* @param effectiveLists
* @param oid
* @return
*/
private List<ItemTO> filterOrder(List<ItemTO> itmeList, long oid) {
return itmeList.stream().filter(p -> {
if (p.getOid().equals(oid)) {
return false;
}
return true;
}).collect(Collectors.toList());
}
- 將list中物件的兩個屬性值分別作為map的key和value
itemList.stream().filter(t -> t.getId() != null)
.collect(Collectors.toMap(ItemTO::getId, ItemTO::getName, (k1, k2)->k2));
- 對list做操作
// 交集
List<String> intersection = list1.stream().filter(item -> list2.contains(item)).collect(toList());
// 差集 (list1 - list2)
List<String> reduce1 = list1.stream().filter(item -> !list2.contains(item)).collect(toList());
// 差集 (list2 - list1)
List<String> reduce2 = list2.stream().filter(item -> !list1.contains(item)).collect(toList());
// 並集
List<String> listAll = list1.parallelStream().collect(toList());
List<String> listAll2 = list2.parallelStream().collect(toList());
listAll.addAll(listAll2);
// 去重並集
List<String> listAllDistinct = listAll.stream().distinct().collect(toList());
System.out.println("---得到去重並集 listAllDistinct---“);
// 迴圈輸出
listAllDistinct.parallelStream().forEachOrdered(System.out :: println);
- map的操作,移除
// 通過value移除
map.values().removeIf(value -> !value.contains("1"));
// 通過key移除
map.keySet().removeIf(key -> key != 1);
// key或者value移除
map.entrySet().removeIf(entry -> entry.getKey() != 1);
- 排序操作
// 升序
itemList = itemList.stream().sorted(Comparator.comparingInt(ItemTO::getPtPrice)).collect(Collectors.toList());
// 降敘
itemList = itemList.stream().sorted(Comparator.comparingInt(ItemTO::getPtPrice).reversed()).collect(Collectors.toList());
- groupBy操作
//a
Map<Long,List<Long>> exhibitionPitemMap = list.stream().collect(Collectors.groupingBy(TestDTO1::getLevle1CategoryId, Collectors.mapping(TestDTO1::getPitemId, Collectors.toList())));
//b
Map<Long, List<TestDTO2>> categoryPitemMap = list.stream().collect(Collectors.groupingBy(TestDTO2::getLevle1CategoryId));
- map轉list用法
Map<String, String> map = new HashMap<>();
// Convert all Map keys to a List
List<String> result = new ArrayList(map.keySet());
// Convert all Map values to a List
List<String> result2 = new ArrayList(map.values());
// Java 8, Convert all Map keys to a List
List<String> result3 = map.keySet().stream() .collect(Collectors.toList());
// Java 8, Convert all Map values to a List
List<String> result4 = map.values().stream() .collect(Collectors.toList());
// Java 8, seem a bit long, but you can enjoy the Stream features like filter and etc.
List<String> result5 = map.values().stream() .filter(x -> !"apple".equalsIgnoreCase(x)) .collect(Collectors.toList());
- 修改list中的元素值
list.stream().filter(a -> 篩選條件).forEach(b -> b.setOrg("1"));