如何缩减具有相同密钥属性的对象列表



我正在尝试concat自定义对象,如果对象的特定键属性匹配

我的数据以下是以下格式。

列表就是这样。

 Data[
{batchNo: "1212", location: "12bbn", qty: "123", rawMaterialId: "6743"},
{batchNo: "1213", location: "12nmn", qty: "300", rawMaterialId: "6743"},
{batchNo: "1241", location: "vbv2", qty: "123", rawMaterialId: "9179"},
{batchNo: "1251", location: "fdsfds", qty: "244", rawMaterialId: "9179"},
{batchNo: "1233", location: "cvcvbc", qty: "200", rawMaterialId: "9169"},
{batchNo: "1266", location: "bnbn", qty: "600", rawMaterialId: "9935"}
]

我正在尝试根据特定的密钥属性即(RawMaterialId)来调节它们。

例如,如果rowmaterialid =索引[0]的6743匹配索引[1],则需要加入。

预期清单

    Data[
      {batchNo: "1212 , 1213", location: "12bbn , 12nmn", qty: "123 , 300", rawMaterialId: "6743"},
{batchNo: "1241,1251", location: "vbv2 , fdsfds", qty: "123,244",rawMaterialId: "9179"},
{batchNo: "1233", location: "cvcvbc", qty: "200", rawMaterialId:"9169"},
{batchNo: "1266", location: "bnbn", qty: "600", rawMaterialId: "9935"}
   ]

我尝试使用循环,但没有获得预期的输出

我尝试的代码

       for(int i=0; i<data.length;i++)
        {
         for(int j=0; i<data.length;i++)
          {
            if(data[i].rawMaterialId == data[j].rawMaterialId )
            {
                data[i].location=data[i].location +","+ data[j].location;
                data[i].batchNo=data[i].batchNo +"," + data[j].batchNo;
                data[i].quantity=data[i].quantity +"," + data[j].quantity;
            }
        } 
}

请帮助我解决任何建议和更正。预先感谢。

如果您具有数组 data ,则可以使用流API对其进行转换。最后一行将 data 替换为项目的真实类型。

data = Arrays.stream(data).       // Create stream from your array
    collect(Collectors.toMap(     // Transform it to Map
        d -> d.rawMaterialId,     // It is keys of creating map
        d -> d,                   // This is values of creating map 
        (d1, d2) -> {             // Function for merging values with same keys. 
                                  // There happens all neded concatenations.
            d1.location = d1.location + "," + d2.location;
            d1.batchNo = d1.batchNo + "," + d2.batchNo;
            d1.quantity = d1.quantity + "," + d2.quantity;
            return d1;
        }).
    values().toArray(new Data[0]); // Transform map to new array. 
                                   // Replace Data to real type of your items.

为什么不将映射与键rawMaterialId和值为数据列表

Map<Integer,List<Data>> map= new HashMap<Integer,List<Data>>();
for(int i=0; i<data.length;i++)
{
if(map.contains(data[i].rawMaterialId))    {
   List<Data> list=map.get(data[i].rawMaterialId);
list.add(data[i]);
}
else    {
 List<Data> list=new ArrayList<Data>();
list.add(data[i]);
map.put(data[i]);
}
}

之后,您可以通过在地图上迭代形成所需的数组。

P.S:这只是一个简短的想法。请原谅我的汇编错误(如果有)

    for (int i = 0; i < data.length ; i++) {
        for (int j = i + 1; i < data.length; i++) {
            if (data[i].rawMaterialId == data[j].rawMaterialId ) {
                    // copy to new Data Array
            }
        }
    } 

最新更新