-
php中array_unique去除二维数组中重复的数组
一个利用php中array_unique实现去除二级数组重复值的方法,有需要的朋友可参考参考.
实例代码如下:
- <?php
- $input = array(“a” => “green”,”", “red”,”b” => “green”, “”,”blue”, “red”,”c” => “witer”,”hello”,”witer”);
- //$result = array_unique($input); //去除重复元素
- $result = a_array_unique($input);?? //只留下单一元素
- foreach($result as $aa)
- {
- echo $aa.”<br />”;
- }
- function multi_unique($array) {
- foreach ($array as $k=>$na)
- $new[$k] = serialize($na);
- $uniq = array_unique($new);
- foreach($uniq as $k=>$ser)
- $new1[$k] = unserialize($ser);
- return ($new1);
- }
- function a_array_unique($array)//写的比较好
- {
- $out = array();
- foreach ($array as $key=>$value) {
- if (!in_array($value, $out))
- {
- $out[$key] = $value;
- }
- }
- return $out;
- }
- ?>
array_unique函数只适用于一维数组,对多维数组并不适用,但是我们利用遍历数据然后再进行操作就可以实现array_unique去除重复数组了.
实例代码如下:
- function unique_arr($array2D,$stkeep=false,$ndformat=true)
- {
- // 判断是否保留一级数组键 (一级数组键可以为非数字)
- if($stkeep) $stArr = array_keys($array2D);
- // 判断是否保留二级数组键 (所有二级数组键必须相同)
- if($ndformat) $ndArr = array_keys(end($array2D));
- //降维,也可以用implode,将一维数组转换为用逗号连接的字符串
- foreach ($array2D as $v){
- $v = join(“,”,$v);
- $temp[] = $v;
- }
- //去掉重复的字符串,也就是重复的一维数组
- $temp = array_unique($temp);
- //再将拆开的数组重新组装
- foreach ($temp as $k => $v)
- {
- if($stkeep) $k = $stArr[$k];
- if($ndformat)
- {
- $tempArr = explode(“,”,$v);
- foreach($tempArr as $ndkey => $ndval) $output[$k][$ndArr[$ndkey]] = $ndval;
- }
- else $output[$k] = explode(“,”,$v);
- }
- return $output;
- }
- $array2D = array(‘first’=>array(‘title’=>’1111′,’date’=>’2222′),’second’=>array(‘title’=>’1111′,’date’=>’2222′),’third’=>array(‘title’=>’2222′,’date’=>’3333′));
- print_r($array2D);
- print_r(unique_arr($array2D,true));
出处:http://www.phpfensi.com/php/20140313/2133.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式