admin管理员组

文章数量:1279124

Demo Object:

var foo = {a:1, b:2, c:3, d:4, e:5, f:6, g:7}

Wanted result: (get top 3 keys by value)

{e:5, f:6, g:7}

Explanation:

For a given key/value basic object, how would you get the 3 top values, but not just the values but also the keys? keys could be anything. lets say values are integers.

performance should be in mind.

Demo Object:

var foo = {a:1, b:2, c:3, d:4, e:5, f:6, g:7}

Wanted result: (get top 3 keys by value)

{e:5, f:6, g:7}

Explanation:

For a given key/value basic object, how would you get the 3 top values, but not just the values but also the keys? keys could be anything. lets say values are integers.

performance should be in mind.

Share Improve this question edited Jan 11, 2020 at 21:13 vsync asked Aug 30, 2015 at 23:38 vsyncvsync 131k59 gold badges340 silver badges422 bronze badges 1
  • 1 Reading this now, I can't seem to understand my own question :) what was I thinking... – vsync Commented Nov 3, 2017 at 21:17
Add a ment  | 

2 Answers 2

Reset to default 11

You can extract the properties into an array, then sort the array:

var foo = {a:1, b:2, c:3, d:4, e:5, f:6, g:7}
var props = Object.keys(foo).map(function(key) {
  return { key: key, value: this[key] };
}, foo);
props.sort(function(p1, p2) { return p2.value - p1.value; });
var topThree = props.slice(0, 3);

If you want the result as an object, just reduce it back to one

var topThreeObj = props.slice(0, 3).reduce(function(obj, prop) {
  obj[prop.key] = prop.value;
  return obj;
}, {});

Get key/value pairs:

let pairs = Object.entries(foo);

Sort them:

pairs.sort((a, b) => a[1] - b[1]);

Turn some back into an object:

let result = Object.fromEntries(pairs.slice(-3));

本文标签: javascriptObject filter by N highest numeric values (of keys)Stack Overflow