我有一个名为props的数组,它包含n个带有对象的数组,所有数组都包含相同数量的对象。
每个对象有4个属性: participation_enabled、name、pathing_enabled、id,这些属性在相同属性id的其他数组中可能有不同的值。
我的目标是找到其他对象数组中不同的所有对象属性,并将它们存储在另一个名为diffs的数组中。
示例:
[
[
{participation_enabled:"false", name:"PropEins", pathing_enabled:"true", id:"prop1"},
{participation_enabled:"false", name:"User Status", pathing_enabled:"false", id:"prop2"},
{participation_enabled:"false", name:"Initial ID", pathing_enabled:"false", id:"prop3"},
{participation_enabled:"false", name:"User ID", pathing_enabled:"false", id:"prop4"},
{participation_enabled:"false", name:"Subdomain", pathing_enabled:"false", id:"prop5"}
],
[
{participation_enabled:"false", name:"PropEins", pathing_enabled:"false", id:"prop1"},
{participation_enabled:"false", name:"Room", pathing_enabled:"false", id:"prop2"},
{participation_enabled:"false", name:"Phase", pathing_enabled:"false", id:"prop3"},
{participation_enabled:"false", name:"Custom Insight 4", pathing_enabled:"false", id:"prop4"},
{participation_enabled:"false", name:"Subdomain", pathing_enabled:"false", id:"prop5"}
],
[
{participation_enabled:"true", name:"PropEins", pathing_enabled:"true", id:"prop1"},
{participation_enabled:"true", name:"User Status", pathing_enabled:"true", id:"prop2"},
{participation_enabled:"true", name:"Trackingcode", pathing_enabled:"true", id:"prop3"},
{participation_enabled:"false", name:"User ID", pathing_enabled:"false", id:"prop4"},
{participation_enabled:"false", name:"Subdomain", pathing_enabled:"false", id:"prop5"}
]
]执行之后,diff数组应该是:
[
{id:"prop1", participation_enabled:["false","true"], pathing_enabled:["false","true"], index:0},
{id:"prop2", participation_enabled:["false","true"], name:["User Status","Room"], participation_enabled:["false","true"], pathing_enabled:["false","true"], index:1},
{id:"prop3", participation_enabled:["false","true"], name:["Initial ID","Phase","Trackingcode"], participation_enabled:["false","true"], pathing_enabled:["false","true"], index:2},
{id:"prop4", name:["User ID","Custom Insight 4"], pathing_enabled:["false","true"], index:3}
]这是如何使用javascript和underscoreJS实现的
var diff = {};
a.forEach(function(val, i){
//first just init start object
if (i == 0) {
val.forEach(function(v1, ind){
diff[v1.id] = {};
diff[v1.id].index = [ind];
for (var key in v1) {
diff[v1.id][key] = [v1[key]];
}
});
}
else {
//for all other values add them into array and remove dups
val.forEach(function(v1){
var id = v1.id;
for (var key in v1) {
diff[id][key].push(v1[key]);
}
});
}
});
//now finalize data removing all that have only unique values
for (var key in diff) {
var nested = diff[key];
var index = nested.index.pop();
for (nestedKey in nested) {
nested[nestedKey] = _.filter(nested[nestedKey], function(item, pos) {
return nested[nestedKey].indexOf(item) == pos;
});
if (nested[nestedKey].length < 2) {delete nested[nestedKey];}
}
diff[key].id = key;
diff[key].index = index
if (_.keys(diff[key]).length < 3) {delete diff[key];}
}
diff = _.values(diff);任何建议和想法都会对我很有帮助.
发布于 2017-04-05 07:48:35
看看IEqualityComparer (https://msdn.microsoft.com/it-it/library/ms132151(v=vs.110).aspx和Except (https://msdn.microsoft.com/it-it/library/bb336390(v=vs.110).aspx ))。
一种方法可以是创建一个自定义比较器,并将您的数据一分为二地比较。或者,您可以对所有元素(不包括出现次数较多的元素)进行分组。
https://stackoverflow.com/questions/43224785
复制相似问题