我有兩個類型為 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
提交
取消