非常实用的5种json数组去重方法,函数实现思路竟是chatgpt帮我写的!

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
可观测可视化 Grafana 版,10个用户账号 1个月
简介: 你敢信这5种json数组去重方法的实现思路竟然是chatgpt写的,chatgpt对函数的理解也太准确了吧!

在日常开发中,我们经常会遇到需要去重json数组中重复的数据的场景。json数组去重有很多种方法,比如:双重for循环去重、利用对象属性名不冲突去重,今天我们介绍几个json数组去重的方法。希望能够帮助到大家。

让我们来看看chatgpt跟进封装的函数写出的具体实现思路吧,大家看看是否逻辑清晰,是否一目了然。

方法一 reduce

实现思路

  1. 判断传入的jsonArr是否符合去重的条件,即长度大于等于2,指定了去重字段,且第一个元素是JSON格式数据;
  2. 如果不符合条件,则直接返回原始数组jsonArr;
  3. 如果符合条件,则利用reduce方法遍历jsonArr,对每个元素进行处理,将其与all中的元素进行比较,如果有元素的指定去重字段与next相同,则返回all,否则将next加入到all中;
  4. 返回去重后的数组uniqueArr。
    ```
    /*
    • json数组去重
    • @param: {Array} jsonArr 去重之前的数组
    • @param {String} field 需要去重的字段值
    • @return {Array} 去重之后的数组
      */
      export function uniqueJsonArrByField(jsonArr, field) {
      // 数组长度小于2 或 没有指定去重字段 或 不是json格式数据
      if (jsonArr.length < 2 || !field || typeof jsonArr[0] !== "object") return jsonArr;
      const uniqueArr = jsonArr.reduce((all, next) => all.some((item) => item[field] == next[field]) ? all : [...all, next], []);
      return uniqueArr;
      }

# 方法二 filter和Map
## 实现思路

1. 判断传入的 jsonArr 是否符合去重的条件,即长度大于等于2,指定了去重字段,且第一个元素是 JSON 格式数据;
2. 如果不符合条件,则直接返回原始数组 jsonArr;
3. 如果符合条件,则创建一个空的 Map 对象 res;
4. 利用数组的 filter() 方法遍历 jsonArr 数组,对每个元素进行处理:
- 判断当前元素的指定去重字段值是否已经存在于 res 中,如果已经存在,则说明该元素重复,直接过滤掉;
- 如果该元素的指定去重字段值不存在于 res 中,则将其加入到 res 中,并返回 true;
5.将过滤后的数组作为返回值返回。
```js
/**
 * json数组去重
 * @param  {Array} jsonArr 去重之前的数组
 * @param  {String} field  需要去重的字段值
 * @return {Array}        去重之后的数组
 */
export function uniqueJsonArrByField(jsonArr, field) {
    // 数组长度小于2 或 没有指定去重字段 或 不是json格式数据
    if (jsonArr.length < 2 || !field || typeof jsonArr[0] !== "object") return jsonArr;
    const res = new Map(); // 标识对象
    const uniqueArr = jsonArr.filter((item) => !res.has(item[field]) && res.set(item[field], true));
    return uniqueArr;
}

方法三 变异for

实现思路

  1. 判断传入的 jsonArr 是否符合去重的条件,即长度大于等于2,指定了去重字段,且第一个元素是 JSON 格式数据;
  2. 如果不符合条件,则直接返回原始数组 jsonArr;
  3. 如果符合条件,则创建一个空对象 obj;
  4. 创建一个空数组 uniqueArr;
  5. 利用 for 循环遍历 jsonArr 数组,对每个元素进行处理:
  • 判断当前元素的指定去重字段值是否已经存在于 obj 中,如果已经存在,则说明该元素重复,直接跳过;
  • 如果该元素的指定去重字段值不存在于 obj 中,则将其加入到 uniqueArr 中,并在 obj 中记录该值;
  1. 将去重后的数组作为返回值返回。
    /**
    * json数组去重
    * @param  {Array} jsonArr 去重之前的数组
    * @param  {String} field  需要去重的字段值
    * @return {Array}        去重之后的数组
    */
    export function uniqueJsonArrByField(jsonArr, field) {
         
     // 数组长度小于2 或 没有指定去重字段 或 不是json格式数据
     if (jsonArr.length < 2 || !field || typeof jsonArr[0] !== "object") return jsonArr;
     let obj = {
         }; // 标识对象
     let uniqueArr = [];
     for(let i = 0; i<jsonArr.length; i++) {
          
         if(!obj[jsonArr[i][field]]){
          
             uniqueArr.push(jsonArr[i]);
             obj[jsonArr[i][field]] = true;
         } 
     }
     return uniqueArr;
    }
    

方法四 for + filter

实现思路

  1. 判断传入的 jsonArr 是否符合去重的条件,即长度大于等于2,指定了去重字段,且第一个元素是 JSON 格式数据;
  2. 如果不符合条件,则直接返回原始数组 jsonArr;
  3. 如果符合条件,则创建一个空数组 uniqueArr,并将 jsonArr 中的第一个元素加入到 uniqueArr 中;
  4. 利用 for 循环遍历 jsonArr 数组,对每个元素进行处理:
  • 用 filter() 方法过滤 uniqueArr 中的元素,查找是否存在指定去重字段值与当前元素相同的元素;
  • 如果存在,则说明该元素重复,直接跳过;
  • 如果不存在,则将该元素加入到 uniqueArr 中;
  1. 将去重后的数组作为返回值返回。
    /**
    * json数组去重
    * @param  {Array} jsonArr 去重之前的数组
    * @param  {String} field  需要去重的字段值
    * @return {Array}        去重之后的数组
    */
    export function uniqueJsonArrByField(jsonArr, field) {
         
     // 数组长度小于2 或 没有指定去重字段 或 不是json格式数据
     if (jsonArr.length < 2 || !field || typeof jsonArr[0] !== "object") return jsonArr;
     let uniqueArr = [jsonArr[0]];
     for (let i = 1; i < jsonArr.length; i++) {
         
         let item = jsonArr[i];
         let filterData = uniqueArr.filter(function (f_item) {
         
             return item[field] && f_item[field] == item[field];
         });
         if (filterData.length == 0) {
          // 如果uniqueArr中不存在item
             uniqueArr.push(item);
         }
     }
     return uniqueArr;
    }
    

方法五 for

实现思路

  1. 判断传入的 jsonArr 是否符合去重的条件,即长度大于等于2,指定了去重字段,且第一个元素是 JSON 格式数据;
  2. 如果不符合条件,则直接返回原始数组 jsonArr;
  3. 如果符合条件,则创建一个空数组 uniqueArr,并将 jsonArr 中的第一个元素加入到 uniqueArr 中;
  4. 利用 for 循环遍历 jsonArr 数组,对每个元素进行处理:
  • 创建一个布尔类型的变量 repeat 作为标识位,初始值为 false;
  • 再用一个 for 循环遍历 uniqueArr 数组,对于每个元素都检查它们的指定去重字段值是否与当前元素的指定去重字段值相同;
  • 如果存在,则说明该元素重复,将标识位设为 true 并跳出循环;
  • 如果不存在,则将该元素加入到 uniqueArr 中;
  1. 将去重后的数组作为返回值返回。
/*
 * json数组去重
 * @param: {Array} jsonArr 去重之前的数组
 * @param  {String} field  需要去重的字段值
 * @return {Array}        去重之后的数组
 */
export function uniqueJsonArrByField(jsonArr, field) {
    // 数组长度小于2 或 没有指定去重字段 或 不是json格式数据
    if (jsonArr.length < 2 || !field || typeof jsonArr[0] !== "object") return jsonArr;
    let uniqueArr = [jsonArr[0]];
    for (let i = 1; i < jsonArr.length; i++) {
        let item = jsonArr[i];
        let repeat = false; // 标识位
        for (let j = 0; j < uniqueArr.length; j++) {
            if (item[field] && item[field] == uniqueArr[j][field]) {
                repeat = true;
                break;
            }
        }
        if (!repeat) {
            uniqueArr.push(item);
        }
    }
    return uniqueArr;
}

大家觉得chatgpt根据函数写出的实现思路准确吗?欢迎留言讨论。


✍创作不易,求关注😄,点赞👍,收藏⭐️

相关文章
|
19天前
|
JSON JavaScript 前端开发
JavaScript原生代码处理JSON的一些高频次方法合集
JavaScript原生代码处理JSON的一些高频次方法合集
|
1月前
|
存储 JSON JavaScript
Python字典和JSON字符串相互转化方法
【2月更文挑战第18天】
60 3
|
3月前
|
Web App开发 前端开发
Chrome 浏览器插件 V3 版本 Manifest.json 文件中 Action 的类型(Types)、方法(Methods)和事件(Events)的属性和参数解析
Chrome 浏览器插件 V3 版本 Manifest.json 文件中 Action 的类型(Types)、方法(Methods)和事件(Events)的属性和参数解析
156 0
|
1月前
|
JSON 数据处理 API
盘点Python中4种读取JSON文件和提取JSON文件内容的方法
盘点Python中4种读取JSON文件和提取JSON文件内容的方法
317 0
|
3月前
|
JSON 数据格式
vscode中读取json文件settings.json进行适配主题的方法
vscode中读取json文件settings.json进行适配主题的方法
|
4月前
|
JSON 数据格式
protobuf与json相互转换的方法
protobuf与json相互转换的方法
50 0
|
4月前
|
XML JSON Android开发
[Android]使用JSONObiect和Gson相关方法实现json数据与kotlin对象的相互转换
[Android]使用JSONObiect和Gson相关方法实现json数据与kotlin对象的相互转换
54 0
|
4月前
|
XML 存储 JSON
实现XML与JSON转换,实测这个方法最便捷
XML和JSON是当今最常用的两种数据格式,在数据交换和存储领域占有重要地位。XML以其树状结构和可扩展性被广泛使用,而JSON则以其轻量级和易读性受到开发者的青睐。有时候,为了更好地利用它们的优点解决数据共享、数据处理和数据存储等问题,我们需要将这两种格式进行转换。本文将介绍如何使用Java实现将XML格式转换成JSON格式。
|
4月前
|
XML JSON API
Json实现根据关键词搜索请求唯品会商品列表数据方法,唯品会商品列表数据接口,唯品会API接口申请指南,支持全站
Json实现根据关键词搜索请求唯品会商品列表数据方法,唯品会商品列表数据接口,唯品会API接口申请指南,支持全站
114 1
|
4月前
|
JSON API 数据格式
Json实现根据关键词搜索请求1688商品列表数据方法,1688商品列表数据接口,1688API接口申请指南
Json实现根据关键词搜索请求1688商品列表数据方法,1688商品列表数据接口,1688API接口申请指南
117 0

热门文章

最新文章

  • 1
    Serverless 应用引擎产品使用之在函数计算中,数据库访问失败如何解决
    8
  • 2
    Serverless 应用引擎产品使用之在阿里云函数计算中发现没有NAC(Native Application Component)选项,且无法自己上传MOD(模块)如何解决
    9
  • 3
    Serverless 应用引擎操作报错合集之在阿里云函数计算中,调用了FC函数但是没有执行或者报错,并且在FC函数后台也看不到调用记录日志如何解决
    8
  • 4
    Serverless 应用引擎操作报错合集之在阿里函数计算中,sd部署启动报错CAExited 报错信息“operation not permitted”如何解决
    6
  • 5
    Serverless 应用引擎操作报错合集之在阿里函数计算中,SD Controlnet Depth 运行过程中出现错误“urllib3 v2.0 only supports OpenSSL 1.1.1+”如何解决
    8
  • 6
    Serverless 应用引擎操作报错合集之在阿里云函数计算中,laravel zip包使用示例的start.sh脚本启动时出现错误代码如何解决
    8
  • 7
    Serverless 应用引擎操作报错合集之在阿里云函数计算中,服务器调用FC函数时出现 "[Errno -3] Temporary failure in name resolution)" 错误如何解决
    6
  • 8
    Serverless 应用引擎操作报错合集之在Serverless 应用引擎中,部署过程中遇到错误代码如何解决
    10
  • 9
    Serverless 应用引擎操作报错合集之在 Serverless 应用引擎中,遇到“没法通过 head 传递灰度标识”如何解决
    9
  • 10
    Serverless 应用引擎操作报错合集之在阿里函数计算中,函数执行超时,报错Function time out after如何解决
    12