javascript二维数组按指定要求进行对象合并遍历的算法开发

javascript二维数组按指定要求进行对象合并遍历的算法开发

项目原数据

从第三方API获取如何格式的数据:

  • "device": "二(1)班",不同班级名称,会重复
  • "name": "二(1)班-电量",不同班级的数据标准
  • "value": 10,数据值
    那实际开发中,如何根据需要进行数据的合并和计算呢?
javascript 复制代码
[{
		"device": "二(1)班",
		"name": "二(1)班-电量",
		"value": 10
	},
	{
		"device": "二(1)班",
		"name": "二(1)班-电流",
		"value": 11
	},
	{
		"device": "二(1)班",
		"name": "二(1)班-电功率",
		"value": 12
	},
	{
		"device": "二(2)班",
		"name": "二(2)班-电量",
		"value": 13
	},
	{
		"device": "二(2)班",
		"name": "二(2)班-电流",
		"value": 14
	},
	{
		"device": "二(2)班",
		"name": "二(2)班-电功率",
		"value": 15
	}
]

项目需求

数据格式

如何按照device相同数值的班级合并成一个数组格式如:

php 复制代码
{"device": "二(1)班","name": "二(1)班-电量,二(1)班-电流,二(1)班-电功率","value": "10,11,12"},
{"device": "二(2)班","name": "二(2)班-电量,二(2)班-电流,二(2)班-电功率","value": "13,14,15"}]

算法开发

在JavaScript中,你可以使用reduce函数来将具有相同"device"的对象合并成一个新的数组。下面是一个例子:

javascript 复制代码
let data = [
    { "device": "二(1)班", "name": "二(1)班-电量", "value": 10 },
    { "device": "二(1)班", "name": "二(1)班-电流", "value": 11 },
    { "device": "二(1)班", "name": "二(1)班-电功率", "value": 12 },
    { "device": "二(2)班", "name": "二(2)班-电量", "value": 13 },
    { "device": "二(1)班", "name": "二(2)班-电流", "value": 14 },
    { "device": "二(1)班", "name": "二(2)班-电功率", "value": 15 }
];

let result = data.reduce((acc, curr) => {
    let found = acc.find(item => item.device === curr.device);
    if (found) {
        found.name += ',' + curr.name;
        found.value += ',' + curr.value;
    } else {
        acc.push({
            device: curr.device,
            name: curr.name,
            value: curr.value
        });
    }
    return acc;
}, []);

console.log(result);

在这个脚本中,我们遍历数据数组,并使用reduce函数来创建一个新的结果数组。对于每一个元素,它会检查是否已经在结果数组中找到一个相同的"device"。如果找到,它会将当前元素的"name"和"value"添加到找到的元素的"name"和"value"上。如果没有找到,它会将当前元素添加到结果数组中。最后,它将打印出结果数组。


@漏刻有时

相关推荐
燃先生._.3 小时前
Day-03 Vue(生命周期、生命周期钩子八个函数、工程化开发和脚手架、组件化开发、根组件、局部注册和全局注册的步骤)
前端·javascript·vue.js
XH华4 小时前
初识C语言之二维数组(下)
c语言·算法
南宫生4 小时前
力扣-图论-17【算法学习day.67】
java·学习·算法·leetcode·图论
拭心4 小时前
Google 提供的 Android 端上大模型组件:MediaPipe LLM 介绍
android
不想当程序猿_4 小时前
【蓝桥杯每日一题】求和——前缀和
算法·前缀和·蓝桥杯
高山我梦口香糖4 小时前
[react]searchParams转普通对象
开发语言·前端·javascript
落魄君子4 小时前
GA-BP分类-遗传算法(Genetic Algorithm)和反向传播算法(Backpropagation)
算法·分类·数据挖掘
菜鸡中的奋斗鸡→挣扎鸡5 小时前
滑动窗口 + 算法复习
数据结构·算法
Lenyiin5 小时前
第146场双周赛:统计符合条件长度为3的子数组数目、统计异或值为给定值的路径数目、判断网格图能否被切割成块、唯一中间众数子序列 Ⅰ
c++·算法·leetcode·周赛·lenyiin