我有一个排序字典,里面有一定数量的条目:
dict = {B:3, A:2, C:2, D:1, E:0, F:0...}
在考虑重复值的同时,是否有任何方法可以过滤字典以找到具有前3个最大值的条目,从而输出?:
output = {B:3, A:2, C:2, D:1}
感谢阅读。。
您可以使用Set
计算不同的值,并过滤有序条目以从中获取对象。
const
object = { B: 3, A: 2, C: 2, D: 1, E: 0, F: 0 },
result = Object.fromEntries(Object
.entries(object)
.sort(([, a], [, b]) => b - a) // just to be sure
.filter((s => ([, v]) => s.add(v).size <= 3)(new Set))
);
console.log(result);
也许这会对您有所帮助。
var dict = {
B: 3,
A: 2,
C: 2,
D: 1,
E: 0,
F: 0
};
// Create items array
var items = Object.keys(dict).map(function(key) {
return [key, dict[key]];
});
// Sort the array based on the second element
items.sort(function(first, second) {
return second[1] - first[1];
});
// Create a new array with only the first 3 items
let slicedArray = items.slice(0, 3);
//Return appropriate value
let dictSorted = slicedArray.reduce((a, x) => ({ ...a,
[x[0]]: x[1]
}), {});
console.log(dictSorted);