热门标签 | 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 )

?>

效果图:


推荐阅读
  • 本文介绍了使用Spark实现低配版高斯朴素贝叶斯模型的原因和原理。随着数据量的增大,单机上运行高斯朴素贝叶斯模型会变得很慢,因此考虑使用Spark来加速运行。然而,Spark的MLlib并没有实现高斯朴素贝叶斯模型,因此需要自己动手实现。文章还介绍了朴素贝叶斯的原理和公式,并对具有多个特征和类别的模型进行了讨论。最后,作者总结了实现低配版高斯朴素贝叶斯模型的步骤。 ... [详细]
  • 本文讨论了如何使用IF函数从基于有限输入列表的有限输出列表中获取输出,并提出了是否有更快/更有效的执行代码的方法。作者希望了解是否有办法缩短代码,并从自我开发的角度来看是否有更好的方法。提供的代码可以按原样工作,但作者想知道是否有更好的方法来执行这样的任务。 ... [详细]
  • Ihaveaworkfolderdirectory.我有一个工作文件夹目录。holderDir.glob(*)>holder[ProjectOne, ... [详细]
  • 电话号码的字母组合解题思路和代码示例
    本文介绍了力扣题目《电话号码的字母组合》的解题思路和代码示例。通过使用哈希表和递归求解的方法,可以将给定的电话号码转换为对应的字母组合。详细的解题思路和代码示例可以帮助读者更好地理解和实现该题目。 ... [详细]
  • Oracle分析函数first_value()和last_value()的用法及原理
    本文介绍了Oracle分析函数first_value()和last_value()的用法和原理,以及在查询销售记录日期和部门中的应用。通过示例和解释,详细说明了first_value()和last_value()的功能和不同之处。同时,对于last_value()的结果出现不一样的情况进行了解释,并提供了理解last_value()默认统计范围的方法。该文对于使用Oracle分析函数的开发人员和数据库管理员具有参考价值。 ... [详细]
  • 006_Redis的List数据类型
    1.List类型是一个链表结构的集合,主要功能有push,pop,获取元素等。List类型是一个双端链表的结构,我们可以通过相关操作进行集合的头部或者尾部添加删除元素,List的设 ... [详细]
  • IjustinheritedsomewebpageswhichusesMooTools.IneverusedMooTools.NowIneedtoaddsomef ... [详细]
  • This article discusses the efficiency of using char str[] and char *str and whether there is any reason to prefer one over the other. It explains the difference between the two and provides an example to illustrate their usage. ... [详细]
  • 十大经典排序算法动图演示+Python实现
    本文介绍了十大经典排序算法的原理、演示和Python实现。排序算法分为内部排序和外部排序,常见的内部排序算法有插入排序、希尔排序、选择排序、冒泡排序、归并排序、快速排序、堆排序、基数排序等。文章还解释了时间复杂度和稳定性的概念,并提供了相关的名词解释。 ... [详细]
  • 本文介绍了贝叶斯垃圾邮件分类的机器学习代码,代码来源于https://www.cnblogs.com/huangyc/p/10327209.html,并对代码进行了简介。朴素贝叶斯分类器训练函数包括求p(Ci)和基于词汇表的p(w|Ci)。 ... [详细]
  • 本文介绍了一道经典的状态压缩题目——关灯问题2,并提供了解决该问题的算法思路。通过使用二进制表示灯的状态,并枚举所有可能的状态,可以求解出最少按按钮的次数,从而将所有灯关掉。本文还对状压和位运算进行了解释,并指出了该方法的适用性和局限性。 ... [详细]
  • BZOJ1233 干草堆单调队列优化DP
    本文介绍了一个关于干草堆摆放的问题,通过使用单调队列来优化DP算法,求解最多可以叠几层干草堆。具体的解题思路和转移方程在文章中进行了详细说明,并给出了相应的代码示例。 ... [详细]
  • 本文介绍了Foundation框架中一些常用的结构体和类,包括表示范围作用的NSRange结构体的创建方式,处理几何图形的数据类型NSPoint和NSSize,以及由点和大小复合而成的矩形数据类型NSRect。同时还介绍了创建这些数据类型的方法,以及字符串类NSString的使用方法。 ... [详细]
  • linux进阶50——无锁CAS
    1.概念比较并交换(compareandswap,CAS),是原⼦操作的⼀种,可⽤于在多线程编程中实现不被打断的数据交换操作࿰ ... [详细]
  • 本文总结了初学者在使用dubbo设计架构过程中遇到的问题,并提供了相应的解决方法。问题包括传输字节流限制、分布式事务、序列化、多点部署、zk端口冲突、服务失败请求3次机制以及启动时检查。通过解决这些问题,初学者能够更好地理解和应用dubbo设计架构。 ... [详细]
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社区 版权所有