非常实用的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根据函数写出的实现思路准确吗?欢迎留言讨论。

相关文章
|
4月前
|
存储 JavaScript 前端开发
【面试题】JS的14种去重方法,看看你知道多少(包含数组对象去重)
【面试题】JS的14种去重方法,看看你知道多少(包含数组对象去重)
|
5月前
|
搜索推荐 算法 Python
如何实现归并排序算法? 要求:编写一个Python函数,输入一个无序列表,返回排序后的列表。
如何实现归并排序算法? 要求:编写一个Python函数,输入一个无序列表,返回排序后的列表。
|
5月前
|
搜索推荐 C++
【C++】lambda解决个性化排序问题(对比仿函数)(代码演示)
【C++】lambda解决个性化排序问题(对比仿函数)(代码演示)
|
6月前
|
人工智能 算法 机器人
List 函数排序操作,用对方法事半功倍!
作为一名程序员,以下这些场景你肯定不陌生, 1.数据分析和处理:在处理大量数据时,需要对数据进行排序以进行进一步的分析和处理。例如,在市场调研中,可能需要按照客户的购买频率对客户列表进行排序,以确定哪些客户最有可能购买产品或服务。 2.报表生成:在生成报表时,往往需要按照特定的顺序对数据进行排列,以便清晰地展示数据。例如,在制定销售报告时,可能需要按照销售额对产品进行排序,以了解哪些产品的销售额最高。 ......
|
8月前
|
JSON 数据格式
非常实用的5种json数组去重方法,函数实现思路竟是chatgpt帮我写的!
你敢信这5种json数组去重方法的实现思路竟然是chatgpt写的,chatgpt对函数的理解也太准确了吧!
107 0
|
前端开发
前端学习案例1-数组反序&排序&乱序的方法
前端学习案例1-数组反序&排序&乱序的方法
51 0
前端学习案例1-数组反序&排序&乱序的方法
|
前端开发
前端学习案例16-数组遍历方法6-reduce
前端学习案例16-数组遍历方法6-reduce
38 0
前端学习案例16-数组遍历方法6-reduce
|
前端开发
前端学习案例13-数组遍历方法4-map使用
前端学习案例13-数组遍历方法4-map使用
50 0
前端学习案例13-数组遍历方法4-map使用
|
前端开发
前端学习案例12-数组遍历方法3-稀疏数组
前端学习案例12-数组遍历方法3-稀疏数组
46 0
前端学习案例12-数组遍历方法3-稀疏数组
|
前端开发
前端学习案例7-数组和字符串方法得总结7
前端学习案例7-数组和字符串方法得总结7
48 0
前端学习案例7-数组和字符串方法得总结7