使用 Array.reduce() 按多个键对数组进行分组
Grouping an array by multiple keys with Array.reduce()
第一次写这里,遇到如下问题。例如,我有以下数组:
const input = [
{
id: 1,
date: "01-01-2021",
source: "TT",
metrics: { conversions: 10, cpl: 3 },
},
{
id: 2,
date: "01-01-2021",
source: "TT",
metrics: { conversions: 15, cpl: 3 },
},
{
id: 3,
date: "01-01-2021",
source: "FB",
metrics: { conversions: 15, cpl: 4 },
},
{
id: 4,
date: "01-01-2021",
source: "FB",
metrics: { conversions: 15, cpl: 4 },
},
{
id: 5,
date: "02-01-2021",
source: "TT",
metrics: { conversions: 5, cpl: 2 },
},
{
id: 6,
date: "02-01-2021",
source: "TT",
metrics: { conversions: 15, cpl: 2 },
},
{
id: 7,
date: "02-01-2021",
source: "FB",
metrics: { conversions: 25, cpl: 1 },
},
{
id: 8,
date: "02-01-2021",
source: "FB",
metrics: { conversions: 30, cpl: 1 },
},
];
我需要得到一个按日期和来源分组的数组,其值将是特定日期所有值的总和,例如下面的结果:
const output = [
{
date: "01-01-2021",
TT: 25,
FB: 30,
},
{
date: "02-01-2021",
TT: 20,
FB: 55,
},
];
在我的解决方案中,我找到了唯一键和日期,但不明白下一步该怎么做。你能帮助我吗?示例代码:
const result = input.reduce((acc, current) => {
const dateItem = acc.find((item) => item.date === current.date);
const sources = input.map((item) => item.source).filter((value, index, self) => self.indexOf(value) === index);
if (dateItem) {
return [...acc.filter((i) => i.date !== current.date), { ...dateItem }];
}
return [...acc, { date: current.date }];
}, []);
使用日期作为键的简单归约循环。全部合并后,您可以使用值来获取数组。
const input = [{
id: 1,
date: "01-01-2021",
source: "TT",
metrics: {
conversions: 10,
cpl: 3
},
},
{
id: 2,
date: "01-01-2021",
source: "TT",
metrics: {
conversions: 15,
cpl: 3
},
},
{
id: 3,
date: "01-01-2021",
source: "FB",
metrics: {
conversions: 15,
cpl: 4
},
},
{
id: 4,
date: "01-01-2021",
source: "FB",
metrics: {
conversions: 15,
cpl: 4
},
},
{
id: 5,
date: "02-01-2021",
source: "TT",
metrics: {
conversions: 5,
cpl: 2
},
},
{
id: 6,
date: "02-01-2021",
source: "TT",
metrics: {
conversions: 15,
cpl: 2
},
},
{
id: 7,
date: "02-01-2021",
source: "FB",
metrics: {
conversions: 25,
cpl: 1
},
},
{
id: 8,
date: "02-01-2021",
source: "FB",
metrics: {
conversions: 30,
cpl: 1
},
},
];
const results = Object.values(input.reduce((o, data) => {
o[data.date] = o[data.date] || { date: data.date };
o[data.date][data.source] = (o[data.date][data.source] || 0) + data.metrics.conversions;
return o;
}, {}));
console.log(results);
Array.reduce
与 Object.values
将给出结果。
const input = [
{ id: 1, date: "01-01-2021", source: "TT", metrics: { conversions: 10, cpl: 3 }, },
{ id: 2, date: "01-01-2021", source: "TT", metrics: { conversions: 15, cpl: 3 }, },
{ id: 3, date: "01-01-2021", source: "FB", metrics: { conversions: 15, cpl: 4 }, },
{ id: 4, date: "01-01-2021", source: "FB", metrics: { conversions: 15, cpl: 4 }, },
{ id: 5, date: "02-01-2021", source: "TT", metrics: { conversions: 5, cpl: 2 }, },
{ id: 6, date: "02-01-2021", source: "TT", metrics: { conversions: 15, cpl: 2 }, },
{ id: 7, date: "02-01-2021", source: "FB", metrics: { conversions: 25, cpl: 1 }, },
{ id: 8, date: "02-01-2021", source: "FB", metrics: { conversions: 30, cpl: 1 }, },
];
const output = input.reduce((acc, curr) => {
if (acc[curr.date]) {
acc[curr.date][curr.source] = (acc[curr.date][curr.source] || 0) + curr.metrics.conversions;
} else {
acc[curr.date] = {
date: curr.date,
[curr.source]: curr.metrics.conversions
}
}
return acc;
}, {});
console.log(Object.values(output));
第一次写这里,遇到如下问题。例如,我有以下数组:
const input = [
{
id: 1,
date: "01-01-2021",
source: "TT",
metrics: { conversions: 10, cpl: 3 },
},
{
id: 2,
date: "01-01-2021",
source: "TT",
metrics: { conversions: 15, cpl: 3 },
},
{
id: 3,
date: "01-01-2021",
source: "FB",
metrics: { conversions: 15, cpl: 4 },
},
{
id: 4,
date: "01-01-2021",
source: "FB",
metrics: { conversions: 15, cpl: 4 },
},
{
id: 5,
date: "02-01-2021",
source: "TT",
metrics: { conversions: 5, cpl: 2 },
},
{
id: 6,
date: "02-01-2021",
source: "TT",
metrics: { conversions: 15, cpl: 2 },
},
{
id: 7,
date: "02-01-2021",
source: "FB",
metrics: { conversions: 25, cpl: 1 },
},
{
id: 8,
date: "02-01-2021",
source: "FB",
metrics: { conversions: 30, cpl: 1 },
},
];
我需要得到一个按日期和来源分组的数组,其值将是特定日期所有值的总和,例如下面的结果:
const output = [
{
date: "01-01-2021",
TT: 25,
FB: 30,
},
{
date: "02-01-2021",
TT: 20,
FB: 55,
},
];
在我的解决方案中,我找到了唯一键和日期,但不明白下一步该怎么做。你能帮助我吗?示例代码:
const result = input.reduce((acc, current) => {
const dateItem = acc.find((item) => item.date === current.date);
const sources = input.map((item) => item.source).filter((value, index, self) => self.indexOf(value) === index);
if (dateItem) {
return [...acc.filter((i) => i.date !== current.date), { ...dateItem }];
}
return [...acc, { date: current.date }];
}, []);
使用日期作为键的简单归约循环。全部合并后,您可以使用值来获取数组。
const input = [{
id: 1,
date: "01-01-2021",
source: "TT",
metrics: {
conversions: 10,
cpl: 3
},
},
{
id: 2,
date: "01-01-2021",
source: "TT",
metrics: {
conversions: 15,
cpl: 3
},
},
{
id: 3,
date: "01-01-2021",
source: "FB",
metrics: {
conversions: 15,
cpl: 4
},
},
{
id: 4,
date: "01-01-2021",
source: "FB",
metrics: {
conversions: 15,
cpl: 4
},
},
{
id: 5,
date: "02-01-2021",
source: "TT",
metrics: {
conversions: 5,
cpl: 2
},
},
{
id: 6,
date: "02-01-2021",
source: "TT",
metrics: {
conversions: 15,
cpl: 2
},
},
{
id: 7,
date: "02-01-2021",
source: "FB",
metrics: {
conversions: 25,
cpl: 1
},
},
{
id: 8,
date: "02-01-2021",
source: "FB",
metrics: {
conversions: 30,
cpl: 1
},
},
];
const results = Object.values(input.reduce((o, data) => {
o[data.date] = o[data.date] || { date: data.date };
o[data.date][data.source] = (o[data.date][data.source] || 0) + data.metrics.conversions;
return o;
}, {}));
console.log(results);
Array.reduce
与 Object.values
将给出结果。
const input = [
{ id: 1, date: "01-01-2021", source: "TT", metrics: { conversions: 10, cpl: 3 }, },
{ id: 2, date: "01-01-2021", source: "TT", metrics: { conversions: 15, cpl: 3 }, },
{ id: 3, date: "01-01-2021", source: "FB", metrics: { conversions: 15, cpl: 4 }, },
{ id: 4, date: "01-01-2021", source: "FB", metrics: { conversions: 15, cpl: 4 }, },
{ id: 5, date: "02-01-2021", source: "TT", metrics: { conversions: 5, cpl: 2 }, },
{ id: 6, date: "02-01-2021", source: "TT", metrics: { conversions: 15, cpl: 2 }, },
{ id: 7, date: "02-01-2021", source: "FB", metrics: { conversions: 25, cpl: 1 }, },
{ id: 8, date: "02-01-2021", source: "FB", metrics: { conversions: 30, cpl: 1 }, },
];
const output = input.reduce((acc, curr) => {
if (acc[curr.date]) {
acc[curr.date][curr.source] = (acc[curr.date][curr.source] || 0) + curr.metrics.conversions;
} else {
acc[curr.date] = {
date: curr.date,
[curr.source]: curr.metrics.conversions
}
}
return acc;
}, {});
console.log(Object.values(output));