我有两个类型为 List 的列表 list1 和 list2Term{long sId;int rowNum;long psid;String name;}List<Term> list1 = new ArrayList<>();List<Term> list2 = new ArrayList<>();我想返回 list1 中的所有项目,其中 (list1.psid != list2.psid)。我试过了,但没用public List<Term> getFilteredRowNum(List<Term> list1, List<Term> list2) { List<Long> psid = list2.stream().map(x -> x.getPsid()).collect(Collectors.toList()); return list1.stream().filter(x -> !psid.contains(x.getPsid())).map(x -> x.getRowNum()+1).collect(Collectors.toList()); }我想获取 list1 中满足休闲条件的所有记录 if(list1.psid != list2.psid)Sample Date:List1: rowNum psId name sid 1 1288 home 101 1 9012 home 101 2 1296 office 150 3 1290 park 161List2: rowNum psId name sid 1 9012 home 101 2 1296 office 150 3 1290 park 161List1 psId not in list2 so I am expecting fallowing list as result from list1Expected: List1 rowNum psId name sid 1 1288 home 101
1 回答
蛊毒传说
TA贡献1895条经验 获得超3个赞
anyMatch
您正在过滤器谓词中寻找一个内部作为:
public List<Term> getFilteredRowNum(List<Term> termList1, List<Term> termList2) { return termList1.stream() .filter(term1 -> termList2.stream() .anyMatch(term2 -> term1.getSId() == term2.getSId() && term1.getPsid() != term2.getPsid())) .collect(Collectors.toList()); }
解决该问题的另一种方法是使用和创建出现在任何列表中的一个Map
ofsid
到一个Set
ofpsid
groupingBy
mapping
Map<Long, Set<Long>> sIdToPsIdsMap = termList2.stream() .collect(Collectors.groupingBy(Term::getSId, Collectors.mapping(Term::getPsid, Collectors.toSet())));
并进一步将其用于filter
以下条件
return termList1.stream() .filter(term1 -> sIdToPsIdsMap.containsKey(term1.getSId()) && !sIdToPsIdsMap.get(term1.getSId()).contains(term1.getPsid())) .collect(Collectors.toList());
添加回答
举报
0/150
提交
取消