热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

php数组函数,php处理数组的函数

*数组的常用函数**数组的排序函数*sort(*rsort(*usort(*asort(*arsort(*uasort(*ksor

/* 数组的常用函数

*

* 数组的排序函数

* sort()

* rsort()

* usort()

* asort()

* arsort()

* uasort()

* ksort()

* krsort()

* uksort()

* uatsort()

* natcasesort()

* array_multisort()

*

* 1.简单的数组排序

* sort() rsort()

* 2.根据键名对数组排序

* ksort() krsort()

* 3.根据元素的值对数组排序

* asort() arsort()

* 4.根据"自然数排序“法对数组排序

* natsort()//区分大小写字母比较 natcasescort()//不区分大小写字母的比较

* 5.根据用户自定义规则对数组排序

* usort() uasort() uksort()对键排序

* 6.对维数组的排序

* array_multisort()

*

* 拆分、合并、分解、接合的数组函数

* 1.array_slice()

* 2.array_splice()//删除

* 3.array_combine()//合并

* 4.array_merge();//合并

* 5.array_intersect();//多个数组的交集

* 6.array_diff();//返回多个数组的差集

*

* 数组与数据结构的函数

* 1.使用数组实现堆栈 //先进后出

* array_push() array_pop()

* 2.使用数组实现队列 //先进先出

* array_unshift() array_shift() unset()

*

*

* 其他与数组操作有关的函数

* array_rand()

* shuffle()

* array_sum()

* range()

*/

//简单数组排序的使用

$data=array(5,8,1,7,2);

sort($data);//元素由小到大进行排序

print_r($data);//Array ( [0] => 1 [1] => 2 [2] => 5 [3] => 7 [4] => 8 )

rsort($data);//元素由大到小进行排序

print_r($data);//Array ( [0] => 8 [1] => 7 [2] => 5 [3] => 2 [4] => 1 )

//根据键名排序的例子

$data_2=array(5=>"five",8=>"eight",1=>"one",7=>"seven",2=>"two");

ksort($data_2);//对数组的下标进行由小到大排序

print_r($data_2);//Array ( [1] => one [2] => two [5] => five [7] => seven [8] => eight )

krsort($data_2);//对数组的下标进行由大到小排序

print_r($data_2);//Array ( [8] => eight [7] => seven [5] => five [2] => two [1] => one )

//根据元素的值对数组排序

$data_3=array("1"=>"Linux","a"=>"Apache","m"=>"MySQL","l"=>"PHP");

//asort() arsort 与 sort() rsort()的区别在于 前者排序后保持原有的键名,后者不保持原有键名,且键名从0开始

asort($data_3);

print_r($data_3);//Array ( [a] => Apache [1] => Linux [m] => MySQL [l] => PHP )

echo '
';

arsort($data_3);

print_r($data_3);//Array ( [l] => PHP [m] => MySQL [1] => Linux [a] => Apache )

echo '
';

sort($data_3);

print_r($data_3);//Array ( [0] => Apache [1] => Linux [2] => MySQL [3] => PHP )

echo '
';

rsort($data_3);

print_r($data_3);//Array ( [0] => PHP [1] => MySQL [2] => Linux [3] => Apache )

echo '
';

//根据”自然数排序法“对数组排序(0-9短者优先)

$data_4=array("file.txt","file11.txt","file2.txt","file22.txt");

sort($data_4);

print_r($data_4);//Array ( [0] => file.txt [1] => file11.txt [2] => file2.txt [3] => file22.txt )

echo '
';

natsort($data_4);

print_r($data_4);//Array ( [0] => file.txt [2] => file2.txt [1] => file11.txt [3] => file22.txt )

echo '
';

natcasesort($data_4);

print_r($data_4);//Array ( [0] => file.txt [2] => file2.txt [1] => file11.txt [3] => file22.txt )

echo '
';

//用户自定义排序函数

$data_5=array("Linux","Apache","MySQL","PHP");

usort($data_5,"sortbylen");//通过元素长度排序

print_r($data_5);//Array ( [0] => PHP [1] => MySQL [2] => Linux [3] => Apache )

function sortbylen($one,$two){

if(strlen($one)==strlen($two))

return 0;

else

return (strlen($one)>strlen($two))?1:-1;

}

echo '
';

//拆分、合并、分解、接合的数组函数

$data_6=array("Linux","Apache","MySQL","PHP");

print_r(array_slice($data_6,1,2));//取下标为1、2的元素

//Array ( [0] => Apache [1] => MySQL ) 下标重置从0开始

echo '
';

print_r(array_slice($data_6,-2,1));//从后边的第二个开始取返回一个,不是从0开始的

//Array ( [0] => MySQL ) 下标重置从0开始

echo '
';

print_r(array_slice($data_6,1,2,true));

//Array ( [1] => Apache [2] => MySQL ) 保留原有的下标

echo '
';

//array_combine()

$a1=array("OS","WebServer","DataBase","Language");

$a2=array("Linux","Apache","MySQL","PHP");

print_r(array_combine($a1,$a2));//第一个参数作为键名,第二个作为值来合并

//Array ( [OS] => Linux [WebServer] => Apache [DataBase] => MySQL [Language] => PHP )

echo '
';

//array_merge()

$a3=array("OS","WebServer","DataBase","Language");

$a4=array("Linux","Apache","MySQL","PHP");

$a5=$a3+$a4;

print_r($a5);//因为两个数组下标重复所以显示这样

//Array ( [0] => OS [1] => WebServer [2] => DataBase [3] => Language )

echo '
';

print_r(array_merge($a3,$a4));//合并并重新索引

//Array ( [0] => OS [1] => WebServer [2] => DataBase [3] => Language [4] => Linux [5] => Apache [6] => MySQL [7] => PHP )

echo '
';

//array_intersect()

$a7=array("OS","WebServer","DataBase","Language",1,2,3);

$a8=array("Linux","Apache","MySQL","PHP",2,3,4);

print_r(array_intersect($a7,$a8));//Array ( [5] => 2 [6] => 3 )

echo '
';

//array_diff()

$a9=array(1,2,3,4);

$a10=array(3,4,5,6);

print_r(array_diff($a9,$a10));//Array ( [0] => 1 [1] => 2 )

//返回第一个数组跟第二个相差的元素

echo '
';

//使用数组实现堆栈

$b=array(1,2,3,4);

$b[]="a";//入栈

array_push($b,"b","c");//使用函数入栈

print_r($b);//Array ( [0] => 1 [1] => 2 [2] => 3 [3] => 4 [4] => a [5] => b [6] => c )

echo '
';

$value=array_pop($b);//使用函数出栈

print_r($b);//Array ( [0] => 1 [1] => 2 [2] => 3 [3] => 4 [4] => a [5] => b )

echo '
';

echo $value;//显示出栈的元素的值 c

echo '
';

//使用数组实现队列

$c=array(1,2,3);

print_r($c);//Array ( [0] => 1 [1] => 2 [2] => 3 )

echo '
';

array_unshift($c,"abc","bcd");//入队

print_r($c);//Array ( [0] => abc [1] => bcd [2] => 1 [3] => 2 [4] => 3 )

echo '
';

$values=array_shift($c);//出队

print_r($c);// Array ( [0] => bcd [1] => 1 [2] => 2 [3] => 3 )

echo '
';

unset($c[2]);//删除指定位置元素

print_r($c);//Array ( [0] => bcd [1] => 1 [3] => 3 )

echo '
';

//array_rand() 随机返回数组下标

$arr=array(1,3,4,5,76,7,99,6,2,3);

echo array_rand($arr);//返回的是随机的数组元素的下标

echo $arr[array_rand($arr)];//随机显示数组元素的值

echo '
';

//shuffle() 随机重新排列数组

$arr2=array(32,35,33);

shuffle($arr2);

print_r($arr2);//数组元素位置随机变换

echo '
';

//array_sum() 求和

$arr3=array(1,3,5);

echo array_sum($arr3); //返回9

echo '
';

print_r($arr3);//Array ( [0] => 1 [1] => 3 [2] => 5 )

echo '
';

//range(最小值,最大值,步长)

$arr4=range(0,100,10);

print_r($arr4);//Array ( [0] => 0 [1] => 10 [2] => 20 [3] => 30 [4] => 40 [5] => 50 [6] => 60 [7] => 70 [8] => 80 [9] => 90 [10] => 100 )

?>

效果图:


推荐阅读
  • 深入解析Linux下的I/O多路转接epoll技术
    本文深入解析了Linux下的I/O多路转接epoll技术,介绍了select和poll函数的问题,以及epoll函数的设计和优点。同时讲解了epoll函数的使用方法,包括epoll_create和epoll_ctl两个系统调用。 ... [详细]
  • STL迭代器的种类及其功能介绍
    本文介绍了标准模板库(STL)定义的五种迭代器的种类和功能。通过图表展示了这几种迭代器之间的关系,并详细描述了各个迭代器的功能和使用方法。其中,输入迭代器用于从容器中读取元素,输出迭代器用于向容器中写入元素,正向迭代器是输入迭代器和输出迭代器的组合。本文的目的是帮助读者更好地理解STL迭代器的使用方法和特点。 ... [详细]
  • 电话号码的字母组合解题思路和代码示例
    本文介绍了力扣题目《电话号码的字母组合》的解题思路和代码示例。通过使用哈希表和递归求解的方法,可以将给定的电话号码转换为对应的字母组合。详细的解题思路和代码示例可以帮助读者更好地理解和实现该题目。 ... [详细]
  • 在Docker中,将主机目录挂载到容器中作为volume使用时,常常会遇到文件权限问题。这是因为容器内外的UID不同所导致的。本文介绍了解决这个问题的方法,包括使用gosu和suexec工具以及在Dockerfile中配置volume的权限。通过这些方法,可以避免在使用Docker时出现无写权限的情况。 ... [详细]
  • 本文介绍了[从头学数学]中第101节关于比例的相关问题的研究和修炼过程。主要内容包括[机器小伟]和[工程师阿伟]一起研究比例的相关问题,并给出了一个求比例的函数scale的实现。 ... [详细]
  • LeetCode笔记:剑指Offer 41. 数据流中的中位数(Java、堆、优先队列、知识点)
    本文介绍了LeetCode剑指Offer 41题的解题思路和代码实现,主要涉及了Java中的优先队列和堆排序的知识点。优先队列是Queue接口的实现,可以对其中的元素进行排序,采用小顶堆的方式进行排序。本文还介绍了Java中queue的offer、poll、add、remove、element、peek等方法的区别和用法。 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 006_Redis的List数据类型
    1.List类型是一个链表结构的集合,主要功能有push,pop,获取元素等。List类型是一个双端链表的结构,我们可以通过相关操作进行集合的头部或者尾部添加删除元素,List的设 ... [详细]
  • 深入理解Kafka服务端请求队列中请求的处理
    本文深入分析了Kafka服务端请求队列中请求的处理过程,详细介绍了请求的封装和放入请求队列的过程,以及处理请求的线程池的创建和容量设置。通过场景分析、图示说明和源码分析,帮助读者更好地理解Kafka服务端的工作原理。 ... [详细]
  • Redis底层数据结构之压缩列表的介绍及实现原理
    本文介绍了Redis底层数据结构之压缩列表的概念、实现原理以及使用场景。压缩列表是Redis为了节约内存而开发的一种顺序数据结构,由特殊编码的连续内存块组成。文章详细解释了压缩列表的构成和各个属性的含义,以及如何通过指针来计算表尾节点的地址。压缩列表适用于列表键和哈希键中只包含少量小整数值和短字符串的情况。通过使用压缩列表,可以有效减少内存占用,提升Redis的性能。 ... [详细]
  • 李逍遥寻找仙药的迷阵之旅
    本文讲述了少年李逍遥为了救治婶婶的病情,前往仙灵岛寻找仙药的故事。他需要穿越一个由M×N个方格组成的迷阵,有些方格内有怪物,有些方格是安全的。李逍遥需要避开有怪物的方格,并经过最少的方格,找到仙药。在寻找的过程中,他还会遇到神秘人物。本文提供了一个迷阵样例及李逍遥找到仙药的路线。 ... [详细]
  • 模板引擎StringTemplate的使用方法和特点
    本文介绍了模板引擎StringTemplate的使用方法和特点,包括强制Model和View的分离、Lazy-Evaluation、Recursive enable等。同时,还介绍了StringTemplate语法中的属性和普通字符的使用方法,并提供了向模板填充属性的示例代码。 ... [详细]
  • Ihaveaworkfolderdirectory.我有一个工作文件夹目录。holderDir.glob(*)>holder[ProjectOne, ... [详细]
  • 本文介绍了一道经典的状态压缩题目——关灯问题2,并提供了解决该问题的算法思路。通过使用二进制表示灯的状态,并枚举所有可能的状态,可以求解出最少按按钮的次数,从而将所有灯关掉。本文还对状压和位运算进行了解释,并指出了该方法的适用性和局限性。 ... [详细]
author-avatar
手机用户2502928627
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有