我有兩個(gè)類型為 List 的列表 list1 和 list2Term{long sId;int rowNum;long psid;String name;}List<Term> list1 = new ArrayList<>();List<Term> list2 = new ArrayList<>();我想返回 list1 中的所有項(xiàng)目,其中 (list1.psid != list2.psid)。我試過(guò)了,但沒(méi)用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 回答

蠱毒傳說(shuō)
TA貢獻(xiàn)1895條經(jīng)驗(yàn) 獲得超3個(gè)贊
anyMatch
您正在過(guò)濾器謂詞中尋找一個(gè)內(nèi)部作為:
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()); }
解決該問(wèn)題的另一種方法是使用和創(chuàng)建出現(xiàn)在任何列表中的一個(gè)Map
ofsid
到一個(gè)Set
ofpsid
groupingBy
mapping
Map<Long, Set<Long>> sIdToPsIdsMap = termList2.stream() .collect(Collectors.groupingBy(Term::getSId, Collectors.mapping(Term::getPsid, Collectors.toSet())));
并進(jìn)一步將其用于filter
以下條件
return termList1.stream() .filter(term1 -> sIdToPsIdsMap.containsKey(term1.getSId()) && !sIdToPsIdsMap.get(term1.getSId()).contains(term1.getPsid())) .collect(Collectors.toList());
添加回答
舉報(bào)
0/150
提交
取消