php 二维数组排序几种方法
有时候为了达到一定目的,需要对二维数组进行排序,现分享一下其实现的方法。
代码如下 | 复制代码 |
$arr=array ( $arr=array ( /** // Get args number. // Get keys to sort by and put them to SortRule array. // Get the values according to the keys and put them to array. // Create the eval string and eval it. |
另外:array_multisort 函数功能也很强大,详细可以参看PHP手册,里面讲的很详细。
我们可以使用array_multisort()这个函数。array_multisort() 函数对多个数组或多维数组进行排序。
参数中的数组被当成一个表的列并以行来进行排序 - 这类似 SQL 的 ORDER BY 子句的功能。第一个数组是要排序的主要数组。数组中的行(值)比较为相同的话,就会按照下一个输入数组中相应值的大小进行排序,依此类推。
第一个参数是数组,随后的每一个参数可能是数组,也可能是下面的排序顺序标志(排序标志用于更改默认的排列顺序)之一:
•SORT_ASC - 默认,按升序排列。(A-Z)
•SORT_DESC - 按降序排列。(Z-A)
随后可以指定排序的类型:
•SORT_REGULAR - 默认。将每一项按常规顺序排列。
•SORT_NUMERIC - 将每一项按数字顺序排列。
•SORT_STRING - 将每一项按字母顺序排列。
语法:array_multisort(array1,sorting order,sorting type,array2,array3...)
•array1:必需。规定输入的数组。
•sorting order:可选。规定排列顺序。可能的值是 SORT_ASC 和 SORT_DESC。
•sorting type:可选。规定排序类型。可能的值是SORT_REGULAR、SORT_NUMERIC和SORT_STRING。
•array2:可选。规定输入的数组。
•array3:可选。规定输入的数组。
字符串键名将被保留,但是数字键将被重新索引,从 0 开始,并以 1 递增。可以在每个数组后设置排序顺序和排序类型。如果没有设置,每个数组参数会使用默认值。
下面是一个例子:
代码如下 | 复制代码 |
<?php |
运行结果:
二维数组如下:
Array
(
[0] => Array
(
[val] => 46
[num] => 49
)
[1] => Array
(
[val] => 8
[num] => 24
)
[2] => Array
(
[val] => 37
[num] => 3
)
[3] => Array
(
[val] => 32
[num] => 35
)
[4] => Array
(
[val] => 19
[num] => 38
)
[5] => Array
(
[val] => 30
[num] => 37
)
)
从二维数组中抽出键为val,单独成另一个数组:
Array
(
[0] => 46
[1] => 8
[2] => 37
[3] => 32
[4] => 19
[5] => 30
)
对其进行排序:
Array
(
[0] => 8
[1] => 19
[2] => 30
[3] => 32
[4] => 37
[5] => 46
)
我们将得到一个按val升序排序的二维数组。
以前我给大家有讲过生成多个随机数,下面我再来介绍一篇关于php 生成N个不重复的随机数实例,如果你有兴趣大家可参考一下。要实现此功能并非难事,但是让我学习到很多。
代码如下 | 复制代码 |
/** * 生成一定数量的不重复随机数 * @param int $min ,$max指定随机数的范围 * @param int $max * @param int $num 指定生成数量 * @return array */ function unique_rand($min, $max, $num) { $count = 0; $return = array(); while ($count < $num) { $return[] = mt_rand($min, $max); $return = array_flip(array_flip($return)); $count = count($return); } shuffle($return); return $return; } |
生成随机数时用了 mt_rand() 函数。这个函数生成随机数的平均速度要比 rand() 快四倍。
去除数组中的重复值时用了“翻翻法”,就是用 array_flip() 把数组的 key 和 value 交换两次。这种做法比用 array_unique() 快得多。
返回数组前,先使用 shuffle() 为数组赋予新的键名,保证键名是 0-n 连续的数字。如果不进行此步骤,可能在删除重复值时造成键名不连续,给遍历带来麻烦。
代码如下 | 复制代码 |
<?php function CreatePropertyArray(){ global $IP; $content = ''; $industris = array(); $industry_tree = array(); $content .= "<?phpn"; //Industry $industries = getMasterPropertyValues('Industry'); foreach($industries as $v){ $industry_tree["$v"]= getSlavePropertyValues("Industry","Product Category", $v); } $content .= '$Industries = '. var_export($industries,true) . ";n"; file_put_contents($IP . '/termwiki_array.php',$content,LOCK_EX); } ?> |
查看了不少资料。也想了很多,总结一下!
php高性能高流量用户登录验证机制用cookie 还是 session?
一、cookie 区别session?
cookie客户端;
session存在服务器端;
session安全。
二、session在分布式上存在难点。
这一点memcache可能会解决一些。但如果不用memcache,解决起来问题大.
三、session在生存周期上不如cookie方便。
四、用cookie的最大问题是服务器需要二次验证。如果用session验证,不如用session,查表也是一样。
这里如果cookie不需要服务器端二次验证,则效率会大幅提高。 估计discuz就是这种思路。
五 session和cookie结合使用问题。这又分成上述各点。
代码如下 | 复制代码 |
<?php class paginator { function __construct () { } static function render($page_type, array $args = array()) { $html = ''; switch ($page_type) { case '1': $html = page_1($channel_code, $page_num, $cur_page, $per_group, $base_url, $n, $v); break; case '2': $html = fpage($row_num, $pagesize, $page, $url); break; case '3': break; default: $html = page($num, $perpage, $curpage, $mpurl, $hiddenFrom=''); } return $html; } //函数1:根据总页数,当前页,和页分组及url产生分页导航 function page_1($channel_code, $page_num, $cur_page, $per_group, $base_url, $n, $v) { // 分页函数参数列表(有多少页,当前页,每页多少个 ,链接地址) $base_url .= strpos($base_url, '?') ? '&' : '?'; //如果有?,则添加&,否则加? $page_val = ""; if ($page_num < 1) { return $page_val; //如果小于1,返回空 } elseif ($page_num == 1) { return $page_val = 1; //如果等于1,返回1 } //分组 $group_ok = !(($page_num-1) % ($per_group-1)); //没有余数 // 计算一共有多少组 if($group_ok) { $group_num = ($page_num-1)/($per_group-1); }else { $group_num = ceil(($page_num-1) / ($per_group-1)); } //判断当前页是否为一组的最后一个 //组数 $is_last_page = !(($cur_page-1) % ($per_group-1)); //计算当前在的组数 if ($is_last_page) { $cur_group = ($cur_page-1) / ($per_group-1) + 1; } else { $cur_group = ceil(($cur_page-1) / ($per_group-1)); } // 计算显示的起始页 ,这个关键 $from = ($cur_group - 1) * ($per_group-1) + 1; $from = $cur_group <= 1 ? 1 :$from; $to = $from + $per_group; $to = $to > $page_num ? $page_num + 1 : $to; for($a = $from; $a < $to; $a++) { if ($a != $cur_page) { //不是当前页 $page_val .= '<li><a href ="' . $base_url . 'channel='.$channel_code.'&n='.$n.'&v='.$v.'&page=' . $a . '">' . $a . '</a></li>'; } else { //当前页 $page_val .='<li class="current">'. $a .'</li>'; } } //上一页下一页首页尾页 $next = $cur_page + 1; //当前页+1 $prev = $cur_page-1; //当前页-1 if ($cur_page != $page_num) { //当前页不是最后一页 $page_val .= '<span><a href ="' . $base_url . 'channel='.$channel_code.'&n='.$n.'&v='.$v.'&page=' . $next . '">' . '下一页' . '</a></span>'; $page_val .= '<span><a href ="' . $base_url . 'channel='.$channel_code.'&n='.$n.'&v='.$v.'&page=' . $page_num . '">' . '>>' . '</a></span>'; //尾页 } if ($cur_page != 1){ //不是第一页,加上前面的内容 $page_val = '<span><a href ="' . $base_url . 'channel='.$channel_code.'&n='.$n.'&v='.$v.'&page=' . $prev . '">' . '上一页' . '</a></span>' . $page_val; $page_val = '<span><a href ="' . $base_url . 'channel='.$channel_code.'&n='.$n.'&v='.$v.'&page=1">' . '<<' . '</a></span>' . $page_val; //首页 } $page_val = '<ul class="page_nav">'.$page_val.'</ul>'; return $page_val; } // 函数2:根据记录数,页列清数,当前页,url年成分页 function fpage($row_num, $pagesize, $page, $url) { //$page,当前页;$row_num记录总数;$pagesize:每页记录数;$url记录页; //如果,如果有作数,则取加1 $page_count = $row_num % $pagesize?intval($row_num / $pagesize) + 1:intval($row_num / $pagesize); if ($page_count == 1) { $page_string = "第一页|上一页|下一页|尾页"; } else { //如果不止一页 if ($page == 1) { //第一页显示 $page_string = " <a href=" . $url . "?page=1>第一页 </a>|上一页| <a href=" . $url . "?page=" . ($page + 1) . ">下一页 </a>| <a href=" . $url . "?page=" . $page_count . ">尾页 </a>"; } if (($page > 1) and ($page < $page_count)) { $page_string = " <a href=" . $url . "?page=1>第一页 </a>| <a href=" . $url . "?page=" . ($page-1) . ">上一页 </a>| <a href=" . $url . "?page=" . ($page + 1) . ">下一页 </a>| <a href=" . $url . "?page=" . $page_count . ">尾页 </a>"; } if ($page == $page_count) { $page_string = " <a href=" . $url . "?page=1>第一页 </a>| <a href=" . $url . "?page=" . ($page-1) . ">上一页 </a>|下一页| <a href=" . $url . "?page=" . $page_count . ">尾页 </a>"; } } $page_str = $page_string . ("," . $page . "/" . $page_count . "页"); echo " <br> <p align=center>" . $page_str . " </p>"; } /** * 分页函数 * * @param int $num:记录总数 * @param int $perpage:每页记录 * @param int $curpage:当前页 * @param string $mpurl:路径url * @param unknown_type $hiddenFrom * @return string */ function page($num, $perpage, $curpage, $mpurl,$hiddenFrom='') { $multipage = ''; //恢复 $mpurl .= strpos($mpurl, '?') ? '&' : '?'; if($num > $perpage) { $page = 10; $offset = 2; $pages = @ceil($num / $perpage); //总页数 if($page > $pages) { $from = 1; $to = $pages; } else { //如果总页数>10 $from = $curpage - $offset; //当前页-2 $to = $from + $page - 1; //当前页+10-3 if($from < 1) { $to = $curpage + 1 - $from; $from = 1; if($to - $from < $page) { $to = $page; } } elseif($to > $pages) { $from = $pages - $page + 1; $to = $pages; } } if ($hiddenFrom) { $multipage = ($curpage - $offset > 1 && $pages > $page ? '<a href="#" '.js_page($hiddenFrom,1).'>首页</a> ' : ''). ($curpage > 1 ? ' <a href="#" '.js_page($hiddenFrom,$curpage - 1).'>‹‹上一页</a> ' : ''); for($i = $from; $i <= $to; $i++) { $multipage .= $i == $curpage ? '<span>'.$i.'</span> ' : '<a href="#" '.js_page($hiddenFrom,$i).'>'.$i.'</a> '; } $multipage .= ($curpage < $pages ? '<a href="#" '.js_page($hiddenFrom,$curpage + 1).'>下一页››</a>' : ''). ($to < $pages ? '<a href="#" '.js_page($hiddenFrom,$pages).'> 末页</a>' : ''); $multipage = $multipage ? '<div class="list-page">'.$multipage.'</div>' : ''; } else { $multipage = ($curpage - $offset > 1 && $pages > $page ? '<a href="'.$mpurl.'page=1">首页</a> ' : ''). ($curpage > 1 ? ' <a href="'.$mpurl.'page='.($curpage - 1).'">‹‹上一页</a> ' : ''); for($i = $from; $i <= $to; $i++) { $multipage .= $i == $curpage ? '<span>'.$i.'</span> ' : '<a href="'.$mpurl.'page='.$i.'">'.$i.'</a> '; } $multipage .= ($curpage < $pages ? '<a href="'.$mpurl.'page='.($curpage + 1).'">下一页››</a>' : ''). ($to < $pages ? '<a href="'.$mpurl.'page='.$pages.'"> 末页</a>' : ''); $multipage = $multipage ? '<div class="list-page">'.$multipage.'</div>' : ''; } } return $multipage; } //暂不用 function page_get_start($page, $ppp, $totalnum) { $totalpage = ceil($totalnum / $ppp); $page = max(1, min($totalpage, intval($page))); return ($page - 1) * $ppp; } //暂不用 function js_page($hiddenFrom,$page) { if ($hiddenFrom) { return ' onclick=javascript:$("#page").val("'.$page.'");$("#'.$hiddenFrom.'").submit(); '; } } } ?> |
相关文章
- 在php中eval是一个函数并且不能直接禁用了,但eval函数又相当的危险了经常会出现一些问题了,今天我们就一起来看看eval函数对数组的操作 例子, <?php $data="array...2016-11-25
- 这篇文章主要介绍了Python 图片转数组,二进制互转操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-03-09
- 本文章提供在量的数据中级操作实例有如对键名比较计算数组的差集 计算差集 给指定数组中插入一个元素 反转数组 交集赋值新的数组实例。 //定义回调函数 funct...2016-11-25
- 这篇文章主要介绍了C#二维数组基本用法,以实例形式分析了C#中二维数组的定义、初始化、遍历及打印等用法,具有一定参考借鉴价值,需要的朋友可以参考下...2020-06-25
- Array数组在C#中同样是最基本的数据结构,下面为大家C#数组的常用操作方法小结,皆为细小的代码段,欢迎收看收藏...2020-06-25
- 下面一段代码给大家介绍php curl模拟post请求的示例代码,具体代码如下: <?php$uri = "http://www.cnblogs.com/test.php";//这里换成自己的服务器的地址// 参数数组$data = array ( 'name' => 'tanteng'// 'passwor...2015-11-24
- 下面小编就为大家带来一篇C# 拷贝数组的几种方法(总结)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...2020-06-25
- 本文记录的要实现的功能类似于 MySQL 中的 ORDER BY,上个项目中有遇到这样的一个需求。 要求:从两个不同的表中获取各自的4条数据,然后整合(array_merge)成一个数组,再根据数据的创建时间降序排序取前4条。 遇到这个...2014-06-07
- 这篇文章主要介绍了C#实现字符串转换成字节数组的简单实现方法,仅一行代码即可搞定,非常简单实用,需要的朋友可以参考下...2020-06-25
- 这篇文章主要介绍了c#将字节数组转成易读的字符串的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-06-25
- 这篇文章主要介绍了C#读取文件所有行到数组的方法,涉及C#针对文件及数组的相关操作技巧,需要的朋友可以参考下...2020-06-25
- 如何将下面的二维数组转为一维数组。复制代码 代码如下:$msg = array( array( 'id'=>'45', 'name'=>'jack' ), array( 'id'=>'34', 'name'=>'mary' ), array( 'id...2014-05-31
- 在php中为我们提供了一个函数var_export 他可以直接将php代码入到一个文件中哦。 代码如下 复制代码 var_export($times,true);后面不加tru...2016-11-25
- 本文为代码分享,也是在工作中看到一些“大牛”的代码,做做分享。 具体是这样的,如下一个二维数组,是从库中读取出来的。 代码清单: 复制代码 代码如下: $user = array( 0 => array( 'id' => 1, 'name' => '张三', 'ema...2014-06-07
- 1.前言 昨天碰到一道关于如何解决有序数组的连接问题,这是一个很常见的问题。但是这里要考虑到代码的效率问题,因为要连接的数组都是有序的,这是一个非常重要的前提条件。2.简单但效率不高的算法 我首先想到的是使用...2013-10-04
- 今天小编就为大家分享一篇python 实现将Numpy数组保存为图像,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-04-27
C#中数组、ArrayList、List、Dictionary的用法与区别浅析(存取数据)
在工作中经常遇到C#数组、ArrayList、List、Dictionary存取数据,但是该选择哪种类型进行存储数据呢?很迷茫,今天小编抽空给大家整理下这方面的内容,需要的朋友参考下吧...2020-06-25- 这篇文章主要介绍了C#中List和数组之间转换的方法,涉及比较简单的转换技巧,需要的朋友可以参考下...2020-06-25
- 下面小编就为大家带来一篇javascript中去除数组重复元素的实现方法【实例】。小编觉得挺不错的,现在分享给大家,也给大家做个参考,一起跟随小编过来看看吧...2016-04-16
- 下面小编就为大家带来一篇Perl与JS的对比分析(数组、哈希)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...2020-06-29