首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何计算对象数组中给定属性的平均值( JavaScript )

如何计算对象数组中给定属性的平均值( JavaScript )
EN

Stack Overflow用户
提问于 2019-03-27 11:19:10
回答 5查看 3.8K关注 0票数 3

我有一系列的对象。每个对象都包含一些属性,其中一个属性是age。

代码语言:javascript
复制
var people = [
  {
    name: 'Anna',
    age: 22
  },
  {
    name: 'Tom',
    age: 34
  }, {
    name: 'John',
    age: 12
  },
]

我想要计算这个数组中所有年龄属性的平均值。我使用这个函数:

代码语言:javascript
复制
let getAverage = arr => {
  let reducer = (total, currentValue) => total + currentValue;
  let sum = arr.reduce(reducer)
  return sum / arr.length;
}

对于简单的数组(如22、34、12 ),它可以很好地工作,但对于对象数组则不然。

如何修改我的getAverage函数,使它也适用于对象数组?

下面是我的代码片段:https://jsfiddle.net/marektchas/kc8Ls0f5/2/

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2019-03-27 11:32:35

您不需要修改getAverage --您可以在关闭数组之前对其进行预处理,在这种情况下,getAverage将完全按照需要工作:

代码语言:javascript
复制
var people = [
  {
    name: 'Anna',
    age: 22
  },
  {
    name: 'Tom',
    age: 34
  }, {
    name: 'John',
    age: 12
  },
]

let getAverage = arr => {
  let reducer = (total, currentValue) => total + currentValue;
  let sum = arr.reduce(reducer)
  return sum / arr.length;
}

let ages = people.map(person => person.age);

console.log(getAverage(ages));

如果您想要更改getAverage,以便它可以处理任何潜在的输入类型,那么您可以添加一个可选的参数来执行值提取,这样您就不必在每个数组上运行一个map

代码语言:javascript
复制
var numbers = [
  1,
  2,
  3,
  4,
  5
]

var people = [
  {
    name: 'Anna',
    age: 22
  },
  {
    name: 'Tom',
    age: 34
  }, {
    name: 'John',
    age: 12
  },
]

var moreComplexObjects = [
  { 
    a: {
      b: {
        c: 6
      }
    }
  },
  { 
    a: {
      b: {
        c: 7
      }
    }
  },
  { 
    a: {
      b: {
        c: 8
      }
    }
  }
]

//the default value of the second parameter is a function that returns the input
let getAverage = (arr, valueExtractor = x => x) => { 

  //extract the value of each element
  let reducer = (total, currentValue) => total + valueExtractor(currentValue);
  let sum = arr.reduce(reducer, 0) //make sure you add an initialiser
  return sum / arr.length;
}

const ageExtractor = person => person.age;
const complexKeyExtractor = obj => obj.a.b.c;

console.log(getAverage(numbers));
console.log(getAverage(people, ageExtractor));
console.log(getAverage(moreComplexObjects, complexKeyExtractor));

请注意,如果您不向Array#reduce提供第二个参数,那么它第一次运行total将是数组的第一个元素,但是第二次和以后,它将是到目前为止的总和。不值得处理这种情况,所以提供一个初始值可以解决这个问题。

票数 5
EN

Stack Overflow用户

发布于 2019-03-27 11:20:59

您可以使用reduce()并将数组中每个对象的属性age添加到ac中。不要忘记传递0(ac的初始值)作为第二个参数,否则它将返回NaN

代码语言:javascript
复制
var people = [
  {
    name: 'Anna',
    age: 22
  },
  {
    name: 'Tom',
    age: 34
  }, {
    name: 'John',
    age: 12
  },
]

let avgs = people.reduce((ac,a) => a.age + ac,0)/people.length
console.log(avgs)

票数 4
EN

Stack Overflow用户

发布于 2019-03-27 11:21:07

我们可以使用Array.reduce计算和,其中acc是累积和,单个对象被分解成age变量,然后用数组长度除以和来计算平均值:

代码语言:javascript
复制
var people = [
  {
    name: 'Anna',
    age: 22
  },
  {
    name: 'Tom',
    age: 34
  }, {
    name: 'John',
    age: 12
  },
];

function getAvg(arr){
 return (people.reduce((acc, {age}) => (acc + age), 0))/arr.length;
}
console.log(getAvg(people));

我们还可以将函数映射到age属性,并通过将数组连接到字符串并在Function构造函数中对其进行计算来计算和:

代码语言:javascript
复制
var people = [
  {
    name: 'Anna',
    age: 22
  },
  {
    name: 'Tom',
    age: 34
  }, {
    name: 'John',
    age: 12
  },
];

function getAvg(arr){
 return (new Function(`return ${people.map(({age}) => age).join("+")}`)()) / arr.length;
}
console.log(getAvg(people));

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55375935

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档