这里有新鲜出炉的 PHP 面向对象编程,程序狗速度看过来!
PHP(外文名: Hypertext Preprocessor,中文名:"超文本预处理器")是一种通用开源脚本语言。语法吸收了 C 语言、Java 和 Perl 的特点,入门门槛较低,易于学习,使用广泛,主要适用于 web 开发领域。PHP 的文件后缀名为 php。
这篇文章主要介绍了 PHP 中 key 和 current,next 的联合运用, 结合实例形式分析了 key 和 current,next 操作数组元素的相关技巧, 需要的朋友可以参考下
本文实例讲述了 PHP 中 key 和 current,next 的联合运用方法。分享给大家供大家参考,具体如下:
问题:
- $arrq = array();
- $arrq['tuc'] = array('sss' = >'ewq', 'shu' = >'sjkah', 'saa' = >'dwjhaz');
- $arrq['tucs'] = array('ssss' = >'ewsq', 'sQhu' = >dwjhaz ','sa12a '=>'dwjQhaz ');
- $arrq['tuca '] = array('sssd '=>'ewqq ','shu2 '=>'sjkah ','saSa '=>'dwjhhaz ');'
如何在不破坏数组结构的情况下去除 $arrq 数组中的重复的值?
思路:先将第一个二维数组中的元素用 array_unique 函数输出。
输出第二个二维数组中的元素时,自己先用 array_unique 处理,再去掉在第一个二维数组中已经存在的元素。
输出第三个时,自己先用 array_unique 处理,再去掉在第一个和第二个二维数组合集中已经存在的元素。
以此类推。
总之,自己先要 array_unqiue 去重,再去掉自身中在前面所在数组元素合集中存在的元素。
以下为代码:
- <?php
- $arrq = array();
- $arrq['tuc'] = array('sss'=>'ewq','shu'=>'sjkah','saa'=>'dwjhaz');
- $arrq['tucs'] = array('ssss'=>'ewsq','sQhu'=>'dwjhaz','sa12a'=>'dwjQhaz');
- $arrq['tuca'] = array('sssd'=>'ewqq','shu2'=>'sjkah','saSa'=>'dwjhhaz');
- $last=array(); //设置一个空的用来比较的数组
- while($arr=current($arrq)) {
- //echo key($arrq);
- $tmp=array_unique($arr); //先清除每个一维数组自身相同的值
- if(count($last)==0) {
- $last=array_merge($last,$arr); //将已经去重的前面的数组合并
- }
- else { // 对其余一维数组进行输出
- //echo key($arrq);
- foreach($arr as $ke=>$va) {
- if(in_array($arr[$ke], $last)) //如果已经存在的元素
- unset($arrq[key($arrq)][$ke]); //删除,此处取得数组元素的KEY值是关键
- }
- $last=array_merge($last,$arr); //将$last变为前面数组的合集,用来进行下次比较
- }
- next($arrq); //指针向后移,这样才能用key函数取得不同的$arrq的下标
- }
- //以下输出处理后的数组
- foreach($arrq as $arr) {
- foreach($arr as $val) {
- echo $val." ";
- }
- echo "<br>";
- }
- ?>
运行结果为:
希望本文所述对大家 PHP 程序设计有所帮助。
来源: http://www.phperz.com/article/17/0827/343656.html