-
PHP中array_slice函数用法介绍
文章专门来详细的介绍了array_slice函数的详细用法以及一些常用的array_slice实例程序,有需要了解的同学可看看.
array_slice() 函数在数组中根据条件取出一段值,并返回.
注释:如果数组有字符串键,所返回的数组将保留键名,参见例子 4.
语法:array_slice(array,offset,length,preserve)
函数在数组中根据条件取出一段值,并返回.
参数:array 必需,规定输入的数组,offset 必需,数值,规定取出元素的开始位置,如果是正数,则从前往后开始取,如果是负值,从后向前取 offset 绝对值.
length 可选,数值,规定被返回数组的长度,如果是负数,则从后向前,选取该值绝对值数目的元素,如果未设置该值,则返回所有元素.
preserve 可选,可能的值:true – 保留键 false – 默认 – 重置键,当为0的时候,将里面的值赋值给一个新的变量,最后返回这个变量,今天闲着翻了一下手册,原来这东西是有现成的函数的:array_slice,代码如下:
- <?php
- $arr = array(0,1,2,3,4);
- var_dump(array_slice($arr,0,2));
- echo "<br/>";
- $arr2 = array('a'=>array('a','a','a'),'b'=>array('b','b','b'));
- var_dump(array_slice($arr2,0,1));
- ?>
- //返回的结果如下:
- array(2) { [0]=> int(0) [1]=> int(1) }
- array(1) { ["a"]=> array(3) { [0]=> string(1) "a" [1]=> string(1) "a" [2]=> string(1) "a" } }
我找到了array_slice函数,非常好用,分享一下:
- <?php
- //假定一个结果集二维数组:
- $arr = array(array('name'=> 'name1','sex' => 'sex1','job' => 'job1'),
- array('name'=> 'name2','sex' => 'sex2','job' => 'job2'),
- array('name'=> 'name3','sex' => 'sex3','job' => 'job3'),
- array('name'=> 'name4','sex' => 'sex4','job' => 'job4'),
- array('name'=> 'name5','sex' => 'sex5','job' => 'job5'),
- array('name'=> 'name6','sex' => 'sex6','job' => 'job6'),
- array('name'=> 'name7','sex' => 'sex7','job' => 'job7'),
- array('name'=> 'name8','sex' => 'sex8','job' => 'job8'),
- array('name'=> 'name9','sex' => 'sex9','job' => 'job9'),
- array('name'=> 'name10','sex' => 'sex10','job' => 'job10'),
- array('name'=> 'name11','sex' => 'sex11','job' => 'job11'),
- array('name'=> 'name12','sex' => 'sex12','job' => 'job12'),
- );
- //计算总记录条数
- $num = count($arr);
- //规定每页显示的条数
- $perpage = 3;
- //计算页数
- $pages = ceil($num/$perpage);
- //echo $num,$perpage,$pagecount;exit;
- if(is_numeric($_REQUEST['page']))
- {
- if($_REQUEST['page']<1){
- $page = 1;
- }elseif($_REQUEST['page']>$pages)
- {
- $page = $pages;
- }else{
- $page = $_REQUEST['page'];
- }
- }else{
- $page = 1;
- }
- $start = ($page-1)*$perpage;
- $newpage = array_slice($arr,$start,$perpage,true);
- //print_r($newpage);exit;
- ?>
- <table cellpadding="0" cellspacing="0" border="1">
- <tr>
- <td>name</td>
- <td>sex</td>
- <td>job</td>
- </tr>
- <?php
- foreach($newpage as $k => $v)
- {
- ?>
- <tr>
- <td><?php echo $v['name']; ?></td>
- <td><?php echo $v['sex']; ?></td>
- <td><?php echo $v['job']; ?></td>
- </tr>
- <?php
- }
- ?>
- </table>
- <?php
- if($page>1){
- echo "<a href='?page=1'>首页</a>";
- echo "<a href='?page=".($page-1)."'>上一页</a>";
- }//开源软件:phpfensi.com
- if($page<$pages)
- {
- echo "<a href='?page=".($page+1)."'>下一页</a>";
- echo "<a href='?page=".$pages."'>末页</a>";
- }
- ?>
出处:http://www.phpfensi.com/php/20140916/5592.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.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式