亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何通過多個屬性找到重復的對象并將它們合并?

如何通過多個屬性找到重復的對象并將它們合并?

達令說 2023-11-01 21:48:31
我正在編寫一個驗證函數,用于 MongoDb 中集合之間的數據標準化我有一個對象:如下所示:class ReleaseTime{  private Date startDate;  private Date endDate;  private List<String> regions;}我必須收集具有相同startDate和相同的所有 ReleaseTime 對象,endDate然后將區域列表合并在一起我已經嘗試過下面的代碼,但它只是按開始日期分組expectedAvailabilities = ungrouppedReleaseTime.stream()            .collect(Collectors.toMap(ReleaseTime::getStartDate,                    Function.identity(),                    (ReleaseTime tb1, ReleaseTime tb2) ->                    {                        tb1.getRegions().addAll(tb2.getRegions());                        tb2.getRegions().clear();                        return tb1;                    })            ).values();感謝您的幫助!
查看完整描述

2 回答

?
躍然一笑

TA貢獻1826條經驗 獲得超6個贊

這是在不使用流的情況下執行您想要的操作的另一種方法:


Map<List<Date>, List<String>> map = new LinkedHashMap<>();

ungrouppedAvailabilites.forEach(a ->

    map.computeIfAbsent(Arrays.asList(a.getStartDate(), a.getEndDate()), // or List.of

                        k -> new ArrayList<>())

       .addAll(a.getRegions()));

這用于按開始日期和結束日期對對象Map.computeIfAbsent區域進行分組ReleaseTime。


如果分組ReleaseTime對象之間存在重復區域并且您不希望重復,則可以使用 aSet而不是 a List:


Map<List<Date>, Set<String>> map = new LinkedHashMap<>();

ungrouppedAvailabilites.forEach(a ->

    map.computeIfAbsent(Arrays.asList(a.getStartDate(), a.getEndDate()), // or List.of

                        k -> new LinkedHashSet<>())

       .addAll(a.getRegions()));

請注意,我使用LinkedHashMap和LinkedHashSet來保持元素的插入順序。


編輯:


如果您需要ReleaseTime對象而不僅僅是其區域,則可以通過一個額外步驟來實現:


Map<List<Date>, ReleaseTime> result = new LinkedHashMap<>();

map.forEach((k, v) -> 

    result.put(k, new ReleaseTime(k.get(0), k.get(1), new ArrayList<>(v))));

這假設有一個ReleaseTime接收所有屬性的構造函數:


public ReleaseTime(Date startDate, Date endDate, List<String> regions) {

    this.startDate = startDate;

    this.endDate = endDate;

    this.regions = regions;

}


查看完整回答
反對 回復 2023-11-01
?
浮云間

TA貢獻1829條經驗 獲得超4個贊

您可以將分組用作:


// Collection<ReleaseTime> ungrouppedAvailabilites...

Collection<ReleaseTime> mergedRegionsCollection = ungrouppedAvailabilites.stream()

        .collect(Collectors.toMap(t -> Arrays.asList(t.getStartDate(), t.getEndDate()),

                Function.identity(), ReleaseTime::mergeRegions))

        .values();

其中mergeRegions實現為:


ReleaseTime mergeRegions(ReleaseTime that) {

    List<String> mergedRegions = this.getRegions();

    mergedRegions.addAll(that.getRegions());

    return new ReleaseTime(this.startDate, this.endDate, mergedRegions);

}

注意:為了避免改變現有對象,您可以使用以下實現:


ReleaseTime mergeRegions(ReleaseTime that) {

    return new ReleaseTime(this.startDate, this.endDate,

            Stream.concat(this.getRegions().stream(), that.getRegions().stream())

                    .collect(Collectors.toList()));

}


查看完整回答
反對 回復 2023-11-01
  • 2 回答
  • 0 關注
  • 147 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號