PHP二维数组根据二维键名去重算法

逆变薄雾
• 阅读 3811

需求

现在有下面一组二维数组:

array(8) {
  [0]=>
  array(2) {
    ["name"]=>
    string(4) "name"
    ["value"]=>
    string(6) "青叶"
  }
  [1]=>
  array(2) {
    ["name"]=>
    string(5) "phone"
    ["value"]=>
    string(11) "13812341234"
  }
  [2]=>
  array(2) {
    ["name"]=>
    string(12) "fileds_507[]"
    ["value"]=>
    string(12) "我是青叶"
  }
  [3]=>
  array(2) {
    ["name"]=>
    string(12) "fileds_508[]"
    ["value"]=>
    string(6) "合肥"
  }
  [4]=>
  array(2) {
    ["name"]=>
    string(12) "fileds_509[]"
    ["value"]=>
    string(3) "男"
  }
  [5]=>
  array(2) {
    ["name"]=>
    string(12) "fileds_510[]"
    ["value"]=>
    string(6) "足球"
  }
  [6]=>
  array(2) {
    ["name"]=>
    string(12) "fileds_510[]"
    ["value"]=>
    string(6) "棒球"
  }
  [7]=>
  array(2) {
    ["name"]=>
    string(12) "fileds_511[]"
    ["value"]=>
    string(16) "2016-12-15T11:15"
  }
}

需要将处于第二维键名为name,其值相同的数组的value合并,形成一个新的数组。

比如上面代码中的namefileds_510的两个二维数组,就应该合并为一个值为足球,棒球的数组。

思路

提到数组,再PHP中我们首先想到了循环,那么这里显然比较适合使用for循环处理,与冒泡排序相似,一个个比较,最好处理。

代码

代码如下:

$public_info = 数组;
for ($i=0;$i<count($public_info);$i++) {
    for ($j=$i+1;$j<count($public_info);$j++) {
        if ($public_info[$j]['name'] == $public_info[$i]['name']) {
            $public_info[$i]['value'] .= ',' . $public_info[$j]['value'];
            unset($public_info[$j]);
        }
    }
}

执行结果:

array(7) {
  [0]=>
  array(2) {
    ["name"]=>
    string(4) "name"
    ["value"]=>
    string(6) "青叶"
  }
  [1]=>
  array(2) {
    ["name"]=>
    string(5) "phone"
    ["value"]=>
    string(11) "13812341234"
  }
  [2]=>
  array(2) {
    ["name"]=>
    string(12) "fileds_507[]"
    ["value"]=>
    string(12) "我是青叶"
  }
  [3]=>
  array(2) {
    ["name"]=>
    string(12) "fileds_508[]"
    ["value"]=>
    string(6) "合肥"
  }
  [4]=>
  array(2) {
    ["name"]=>
    string(12) "fileds_509[]"
    ["value"]=>
    string(3) "男"
  }
  [5]=>
  array(2) {
    ["name"]=>
    string(12) "fileds_510[]"
    ["value"]=>
    string(13) "足球,棒球"
  }
  [7]=>
  array(2) {
    ["name"]=>
    string(12) "fileds_511[]"
    ["value"]=>
    string(16) "2016-12-15T11:15"
  }
}

总结

需求已搞定,只要遇到数组,我们第一个想到的除了现成的PHP方法之外,就是循环,不管是foreach还是for,上面例子是我项目处理的一个自定义表单编辑的小段过程,希望对大家思路有帮助。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
1年前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Stella981 Stella981
3年前
JS 对象数组Array 根据对象object key的值排序sort,很风骚哦
有个js对象数组varary\{id:1,name:"b"},{id:2,name:"b"}\需求是根据name或者id的值来排序,这里有个风骚的函数函数定义:function keysrt(key,desc) {  return function(a,b){    return desc ? ~~(ak
Wesley13 Wesley13
3年前
PHP创建多级树型结构
<!lang:php<?php$areaarray(array('id'1,'pid'0,'name''中国'),array('id'5,'pid'0,'name''美国'),array('id'2,'pid'1,'name''吉林'),array('id'4,'pid'2,'n
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Wesley13 Wesley13
3年前
ES6 新增的数组的方法
给定一个数组letlist\//wu:武力zhi:智力{id:1,name:'张飞',wu:97,zhi:10},{id:2,name:'诸葛亮',wu:55,zhi:99},{id:3,name:'赵云',wu:97,zhi:66},{id:4,na
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这
美凌格栋栋酱 美凌格栋栋酱
5个月前
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(