如果有这个数组:
[
{
"name" : "lala",
"source_ip" : "10.10.10.10"
},
{
"name" : "lulu",
"source_ip" : "10.10.10.11"
},
{
"name" : "lolo",
"source_ip" : "10.10.10.10"
}
]
我想按出现次数分组并使用 Lodash 对其进行排序以获得此结果:
[
{
"source_ip" : "10.10.10.10",
"count" : 2
},
{
"source_ip" : "10.10.10.11",
"count" : 1
},
]
这是我尝试过的:
app.filter('top10', function() {
return function(incidents) {
return _.chain(incidents)
.countBy("source_ip")
.value();
};
});
我之前也尝试过 reduce 然后改用 grouBy 但它不起作用。
非常感谢。
最佳答案
这将帮助您:
_(array)
.countBy("source_ip")
.map(function(count, ip) { return { count: count, source_ip: ip }})
.sortBy('-count')
.value()
注意事项:
sortBy('-count')
按属性反向排序map
可以迭代对象并传递给函数键,所以你可以从对象生成数组_()
符号表示_.chain()
更新 2017.01.20
我们甚至可以做得更优雅:
_(array)
.countBy("source_ip")
.invert()
.sortBy('-count')
.value()
关于javascript - 按出现次数对数组进行分组并使用 Lodash 对其进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37656597/