我正在尝试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
}
}
}