欢迎来到 黑吧安全网 聚焦网络安全前沿资讯,精华内容,交流技术心得!

PHP二维去重算法的方法

来源:本站整理 作者:佚名 时间:2016-12-28 TAG: 我要投稿

需求
现在有下面一组二维数组:
 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合并,形成一个新的数组。
比如上面代码中的name为fileds_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,上面例子是我项目处理的一个自定义表单编辑的小段过程

【声明】:黑吧安全网(http://www.myhack58.com)登载此文出于传递更多信息之目的,并不代表本站赞同其观点和对其真实性负责,仅适于网络安全技术爱好者学习研究使用,学习中请遵循国家相关法律法规。如有问题请联系我们,联系邮箱admin@myhack58.com,我们会在最短的时间内进行处理。
  • 最新更新
    • 相关阅读
      • 本类热门
        • 最近下载