两数组根据数组中每条数据对象中的某个值合并去重

假设有两个数组:arr1 和 arr2,并且每个数组中的元素是对象,你希望根据对象中的某个属性(比如 id),判断 arr2 中是否已经存在具有相同 id 值的对象。如果没有重复,就将 arr1 中的该对象新增到 arr2 中,否则不新增。

const arr1 = [{ id: 1, name: 'Alice' },{ id: 2, name: 'Bob' },{ id: 3, name: 'Charlie' },
];const arr2 = [{ id: 2, name: 'Bob' },{ id: 4, name: 'David' },
];

在这个例子中,arr1 中有 id 为 2 的对象,arr2 也有 id 为 2 的对象,因此不应该新增这个对象。最终结果应该是新增 id 为 1 和 3 的对象到 arr2 中。

实现方法:
方法 1:使用 Array.prototype.some

arr1.forEach(item1 => {const isDuplicate = arr2.some(item2 => item2.id === item1.id);if (!isDuplicate) {arr2.push(item1);}
});console.log(arr2);
// 输出: [
//   { id: 2, name: 'Bob' },
//   { id: 4, name: 'David' },
//   { id: 1, name: 'Alice' },
//   { id: 3, name: 'Charlie' }
// ]

方法 2:使用 Set 提高效率
当数据量较大时,使用 Set 来记录 arr2 中已存在的 id 值,可以减少 some 方法的遍历时间,提高性能。

const idSet = new Set(arr2.map(item => item.id));arr1.forEach(item => {if (!idSet.has(item.id)) {arr2.push(item);idSet.add(item.id); // 记录新增的 id,避免重复检查}
});console.log(arr2);
// 输出: [
//   { id: 2, name: 'Bob' },
//   { id: 4, name: 'David' },
//   { id: 1, name: 'Alice' },
//   { id: 3, name: 'Charlie' }
// ]

方法 3:使用 Map 进行查重和合并
如果需要对对象的其他属性进行合并或更新,可以使用 Map,它的键值对查找速度更快。

const map = new Map(arr2.map(item => [item.id, item]));arr1.forEach(item => {if (!map.has(item.id)) {map.set(item.id, item);arr2.push(item); // 新增到 arr2 中}
});console.log(arr2);
// 输出: [
//   { id: 2, name: 'Bob' },
//   { id: 4, name: 'David' },
//   { id: 1, name: 'Alice' },
//   { id: 3, name: 'Charlie' }
// ]

解释:
forEach 和 some:

遍历 arr1 中的每一个对象,使用 some 方法检查 arr2 中是否有相同 id 的对象。
如果 some 返回 false(表示没有重复),则将该对象新增到 arr2 中。
Set:

Set 用于快速记录和查找 id,避免重复。
使用 Set 能减少重复检查的时间复杂度,从而提高性能,特别是在数据量较大的情况下。
Map:

Map 用于将 id 作为键,快速查找是否已经存在对应的对象。
这种方法也可以扩展用于更新已有对象的属性,而不是简单地跳过重复对象。
总结:
当数组较小时,使用 forEach + some 是一种简单直观的方法。
当数组较大时,使用 Set 或 Map 可以显著提高查重的效率。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/59317.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

16008.行为树(五)-自定义数据指针在黑板中的传递

文章目录 1.1 背景1.2 xml文件定义1.3 代码实现1.3 执行结果1.1 背景 自定义数据结构指针,通过黑板的形式,在树的节点中进行指针的传递。 1.2 xml文件定义 xhome@ubuntu:~/opt/groot_pro$ cat unit_t1.xml<?xml version="1.0" encoding="UTF-8"?&…

【MongoDB】MongoDB的核心-索引原理及索引优化、及查询聚合优化实战案例(超详细)

文章目录 一、数据库查询效率问题引出索引需求二、索引的基本原理及作用&#xff08;一&#xff09;索引的创建及数据组织&#xff08;二&#xff09;不同类型的索引&#xff08;三&#xff09;索引的额外属性 三、索引的优化与查询计划分析&#xff08;一&#xff09;通过prof…

企业如何实现无缝数据中心进行大数据迁移呢?

数据中心迁移是企业面临的一个复杂而关键的挑战&#xff0c;涉及到大量的数据移动和系统的重新部署。随着业务的扩展和技术的进步&#xff0c;企业可能需要将数据中心迁移到新的位置或升级到更先进的设备。在进行数据迁移时&#xff0c;必须精心规划和执行&#xff0c;以确保数…

FOFA使用教程之从零到精通

FOFA使用教程之从零到精通 前言一、关于网络资产测绘的概念1、啥是网络空间资产测绘2、啥是互联网资产二、FOFA的简要介绍1、FOFA地址是啥?2、关于FOFA的简要介绍三、FOFA精讲1、运算符规则详解① 关于 = 号的使用说明② 关于 == 号的使用说明③ 关于 && 号的使用说明…

初始JavaEE篇 —— 网络编程(2):了解套接字,从0到1实现回显服务器

找往期文章包括但不限于本期文章中不懂的知识点&#xff1a; 个人主页&#xff1a;我要学编程程(ಥ_ಥ)-CSDN博客 所属专栏&#xff1a;JavaEE 目录 TCP 与 UDP Socket套接字 UDP TCP 网络基础知识 在一篇文章中&#xff0c;我们了解了基础的网络知识&#xff0c;网络的出…

【人工智能】10分钟解读-深入浅出大语言模型(LLM)——从ChatGPT到未来AI的演进

文章目录 一、前言二、GPT模型的发展历程2.1 自然语言处理的局限2.2 机器学习的崛起2.3 深度学习的兴起2.3.1 神经网络的训练2.3.2 神经网络面临的挑战 2.4 Transformer的革命性突破2.4.1 Transformer的核心组成2.4.2 Transformer的优势 2.5 GPT模型的诞生与发展2.5.1 GPT的核心…

Webpack 中无法解析别名路径的原因及解决方案

Webpack 中无法解析别名路径的原因及解决方案 文章目录 Webpack 中无法解析别名路径的原因及解决方案1. 引言2. 理解别名路径&#xff08;Alias&#xff09;2.1 什么是别名路径&#xff1f;2.2 别名路径的优势 3. 如何在Webpack中配置别名路径3.1 基本配置3.2 使用别名路径 4. …

最全最简单理解迭代器

1. 迭代器的基础概念(iterator) 1.1 本质 迭代器能够用来遍历容器的对象,与能够遍历数组的指针类似,是广义指针。 1.2 作用: 能够让迭代器与算法不干扰的相互发展,最后又能无间隙的粘合起来。重载了*,++,==,!=,=运算符。用以操作复杂的数据结构。容器提供迭代…

MTSET可溶于DMSO、DMF、THF等有机溶剂,并在水中有轻微的溶解性,91774-25-3

一、基本信息 中文名称&#xff1a;[2-(三甲基铵)乙基]甲硫基磺酸溴&#xff1b;MTSET巯基反应染料 英文名称&#xff1a;MTSET&#xff1b;[2-(Trimethylammonium)ethyl]methanethiosulfonate Bromide CAS号&#xff1a;91774-25-3 分子式&#xff1a;C6H16BrNO2S2 分子量…

CC1链学习记录

&#x1f338; 前言 上篇文章学习记录了URLDNS链&#xff0c;接下来学习一下Common-Colections利用链。 &#x1f338; 相关介绍 Common-Colections是Apache软件基金会的项目&#xff0c;对Java标准的Collections API提供了很好的补充&#xff0c;在其基础上对常用的数据结构…

Android 配置默认输入法

1.背景 最近有个国内的项目&#xff0c;预制了输入法apk&#xff0c;但是无法调出软键盘。原因是没有配置默认输入法&#xff0c;本文主要记录下如何配置默认输入法。 2.代码设置 设置默认输入法需要配置Settings.Secure.ENABLED_INPUT_METHODS和Settings.Secure.DEFAULT_IN…

【juc】ConcurrentHashMap

目录 1.说明2.基本结构3.线程安全机制3.1 分段锁3.2 CAS操作3.3 volatile关键字 4.扩容机制5.其他特性 1.说明 1.ConcurrentHashMap是Java中的一个线程安全的哈希表实现。 2.ConcurrentHashMap的底层结构主要由数组、链表和红黑树组成。 3.在JDK 1.8及之后的版本中&#xff0c;…

数据湖与数据仓库的区别

数据湖与数据仓库是两种不同的数据存储和管理方式&#xff0c;它们在多个方面存在显著的区别。以下是对数据湖与数据仓库区别的详细阐述&#xff1a; 一、数据存储方式 数据仓库 通常采用预定义的模式和结构来存储数据。数据在存储前通常经过清洗、转换和整合等处理&#xff0…

数据结构PTA

20&#xff1a;C 22&#xff1a;B 27&#xff1a;D 填空 4-2&#xff1a;19 4-4&#xff1a;66 4-5&#xff1a;8 5-x&#xff1a;不加分号 ⬇&#xff1a;top p->next 编程 单链表 每个节点除了存放数据元素外&#xff0c;还要存储指向下一节点的指针…

有哪些机器学习实战?——AI实战指南

机器学习已经从理论走向实际应用&#xff0c;各行业的公司和个人都希望通过机器学习来解决现实问题&#xff0c;提升效率。那么&#xff0c;有哪些值得学习和实践的机器学习项目呢&#xff1f;以下将介绍几类热门的机器学习实战项目&#xff0c;涵盖了推荐系统、图像识别、自然…

go语言中的通道(channel)详解

在 Go 语言中&#xff0c;通道&#xff08;channel&#xff09; 是一种用于在 goroutine&#xff08;协程&#xff09;之间传递数据的管道。通道具有类型安全性&#xff0c;即它只能传递一种指定类型的数据。通道是 Go 并发编程的重要特性&#xff0c;能够让多个 goroutine 之间…

Flutter-Padding组件

1. 说明 在html中常见的布局标签都有padding属性&#xff0c;但是Flutter中很多Widget是没有padding属性。这个时候 我们可以用Padding组件处理容器与子元素之间的间距 2. 属性 padding&#xff1a;padding值, EdgeInsetss设置填充的值 child&#xff1a;子组件 3. …

多叉树笔记

1 多叉树定义 多叉树是一种树形结构&#xff0c;它有一个特定的节点被称为“根”节点&#xff0c;而每个节点&#xff08;除了根节点&#xff09;恰好有一个前驱节点&#xff08;父节点&#xff09;。在有根多叉树中&#xff0c;每个节点可以拥有任意数量的后继节点&#xff0…

框架学习04-Spring 事务

1. 事务的基本概念 定义&#xff1a;事务是一组数据库操作的集合&#xff0c;这些操作要么全部成功执行&#xff0c;要么全部不执行。它是为了保证数据的一致性和完整性。例如&#xff0c;在一个银行转账系统中&#xff0c;从一个账户扣款和向另一个账户收款这两个操作应该作为…

【学术会议介绍,SPIE 出版】第四届计算机图形学、人工智能与数据处理国际学术会议 (ICCAID 2024,12月13-15日)

第四届计算机图形学、人工智能与数据处理国际学术会议 2024 4th International Conference on Computer Graphics, Artificial Intelligence and Data Processing (ICCAID 2024) 重要信息 大会官网&#xff1a;www.iccaid.net 大会时间&#xff1a;2024年12月13-15日 大会地…