首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >对象数组操作

对象数组操作
EN

Stack Overflow用户
提问于 2018-12-31 00:46:29
回答 2查看 408关注 0票数 8

我觉得我很接近答案,但我并没有准确地输出我想要的格式

所以,我有一个数组的对象:

代码语言:javascript
复制
const data = [
{email: '100@email.com', amount: '30', date: '2018-12'},
{email: '100@email.com', amount: '30', date: '2018-11'},
{email: '100@email.com', amount: '30', date: '2018-10'},

{email: '200@email.com', amount: 0,    date: '2018-12'},
{email: '200@email.com', amount:'30',  date: '2018-11'},
{email: '200@email.com', amount:'30',  date: '2018-10'},
{email: '200@email.com', amount:'30',  date: '2018-09'},
{email: '200@email.com', amount:'25',  date: '2018-08'},
{email: '200@email.com', amount:'25',  date: '2018-08'},]

正如您在数据集中所看到的,有重复的电子邮件以及重复的对象,比如数据集中的最后两个。

我想把它转换成一个对象数组:

代码语言:javascript
复制
const data = [
{
    email: '100@email.com',
    '2018-12': '30',
    '2018-11': '30',
    '2018-10': '30', 
    '2018-09': 0, 
    '2018-08': 0, 
    '2018-07': 0, 
    '2018-06': 0, 
    '2018-05': 0, 
    '2018-04': 0, 
    '2018-03': 0, 
    '2018-02': 0, 
    '2018-01': 0, 
    '2017-12': 0, 
},
{
    email: '200@email.com',
    '2018-12':0,
    '2018-11':'30',
    '2018-10':'30',
    '2018-09':'30',
    '2018-08':'25',
    '2018-07': 0,
    '2018-06': 0,
    '2018-05': 0,
    '2018-04': 0,
    '2018-03': 0,
    '2018-02': 0,
    '2018-01': 0,
    '2017-12': 0,
}]

输出的日期范围从2017-12到2018-12,日期键的值是该特定日期的金额,否则如果在对象上找不到日期,则该日期的值默认为0。

目前,我正在使用如下所示的方法来处理还原()函数:

代码语言:javascript
复制
let result = data.reduce((acc, {email, date, amount}) => {
    acc.email = email
    acc[date] = amount
    return acc;
}, {});

结果只是返回最后一封电子邮件,没有确切的日期范围,我想要的。

提前谢谢你的帮助。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-12-31 00:50:39

减少为每个email索引的对象,如果累加器上还不存在[email]属性,则显式地创建内部对象。一旦确定对象存在,就可以分配给acc[email][date],最后,使用Object.values将对象转换回所需的数组格式:

代码语言:javascript
复制
const data = [
{email: '100@email.com', amount: '30', date: '2018-12'},
{email: '100@email.com', amount: '30', date: '2018-11'},
{email: '100@email.com', amount: '30', date: '2018-10'},

{email: '200@email.com', amount: 0,    date: '2018-12'},
{email: '200@email.com', amount:'30',  date: '2018-11'},
{email: '200@email.com', amount:'30',  date: '2018-10'},
{email: '200@email.com', amount:'30',  date: '2018-09'},
{email: '200@email.com', amount:'25',  date: '2018-08'},
{email: '200@email.com', amount:'25',  date: '2018-08'},]

let result = data.reduce((acc, {email, date, amount}) => {
  if (!acc[email]) acc[email] = { email };
  acc[email][date] = amount;
  return acc;
}, {});
console.log(Object.values(result));

票数 10
EN

Stack Overflow用户

发布于 2018-12-31 06:33:55

代码语言:javascript
复制
const data = [
  {email: '100@email.com', amount: '30', date: '2018-12'},
  {email: '100@email.com', amount: '30', date: '2018-11'},
  {email: '100@email.com', amount: '30', date: '2018-10'},
  {email: '200@email.com', amount: 0,    date: '2018-12'},
  {email: '200@email.com', amount:'30',  date: '2018-11'},
  {email: '200@email.com', amount:'30',  date: '2018-10'},
  {email: '200@email.com', amount:'30',  date: '2018-09'},
  {email: '200@email.com', amount:'25',  date: '2018-08'},
  {email: '200@email.com', amount:'25',  date: '2018-08'},
];

/*
  Reduce into an object with email as key and email 
  and date/amount(s) as value, wrapped in Object.values 
  to return the array of augmented data values.
*/
augmentData = (data) => Object.values(
  data.reduce((acc, {email, amount, date}) => {
    (acc[email] || (acc[email] = {email}))[date] = amount;
    return acc;
  }, {})
);

/*
  Reduce straight to array of augmented data 
  objects containing email and date/amount values.
*/
augmentData2 = data => data.reduce((acc, {email, amount, date}) => {
  const findEl = (arr) => arr.find(el => el.email == email);
  const createEl = (arr, email) => arr.push({email}) && findEl(arr);
  
  (findEl(acc) || createEl(acc, email))[date] = amount;
  return acc;
}, []);

const augmentedData = augmentData(data);
console.log('augmentedData', augmentedData);

const augmentedData2 = augmentData2(data);
console.log('augmentedData2', augmentedData2);

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

https://stackoverflow.com/questions/53982636

复制
相关文章

相似问题

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