This article first introduces the array definition and destruction of arrays in PHP, and then uses an example to illustrate the sorting method of one-dimensional data. Friends in need can refer to it. I hope it will be useful to everyone.
Definition of PHP array
The code is as follows | Copy code | ||||||||
$array = array('one','two','three'); var_dump($array);
|
The code is as follows | Copy code | ||||||||
array(3) { [0]=>
[1]=> string(3) "two"
string(5) "three" }
|
代码如下 | 复制代码 |
…… $array = array(-5=>'one',"hello"=>'two','three'); var_dump($array); …… |
The code is as follows | Copy code |
…… $array = array('one',"hello"=>'two','three'); var_dump($array); |
The code is as follows | Copy code |
array(3) { [0]=> string(3) "one" ["hello"]=> string(3) "two" [1]=> string(5) "three" } |
The code is as follows | Copy code |
…… $array = array(-5=>'one',"hello"=>'two','three'); var_dump($array); …… |
If you take it for granted that the key name of the third element should be -4, then I tell you that this idea was correct before PHP4.3.0, but it was wrong after that, and now it is after PHP4.3.0 Version you will see the following results:
The code is as follows | Copy code | ||||
[-5]=> string(3) "one"
["hello"]=> } |
Yes, the third element starts from 0, that is, no matter how small your negative number is, if the next element is asked to define the key name by PHP, then it will start from 0 - remember this place says What's interesting is that if the largest key name among the existing keys is still a negative number, no matter how small the negative number is, PHP will start the next key name from zero.
Destruction of PHP arrays is as simple as destroying other variables.
Destroy the entire array: unset($array)
代码如下 | 复制代码 |
$a = array("a"=>1,2); 看一下第一个输出结果,第一个输出: |
Whether in real life or in the programming world, order is always important - I can’t imagine what a world without order would be like! PHP arrays are no exception. PHP provides four sets of functions for sorting PHP arrays. The first three are for one-dimensional arrays. Let's talk about these three first. The fourth sorting of multi-dimensional arrays will be discussed in the next article. That one is a bit complicated.
代码如下 | 复制代码 |
array(2) { ["a"]=> int(1) [0]=> int(2) } array(2) { [0]=> int(2) ["a"]=> int(1) } |
The code is as follows | Copy code |
$a = array("a"=>1,2); sort($a); var_dump($a); rsort($a); var_dump($a); ?> Look at the first output result, the first output: array(2) { [0]=> int(1) [1]=> int(2) } Second output: array(2) { [0]=> int(5) [1]=> int(4) } |
The code is as follows | Copy code |
array(2) { ["a"]=> int(1) [0]=> int(2) } array(2) { [0]=> int(2) ["a"]=> int(1) } |
这个一看就明白的,不用说了吧!
第三组PHP数组排序函数:krsort 和 ksort 这两个不同于以上两组,这两函数是对键名进行排序的,大家可以把上例的函数替换成这两个,看看具体运行结果,这里也不说了,不然这个文章写的就太长了,怕有些兄弟没有耐心看到本文的重点,虽然重点就在下边!
通过自定义函数对PHP数组进行排序,有三个函数分别是:
uasort 通过自定义函数对PHP数组的键值进行排序,并且保留原来的索引关系。
uksort 通过自定义函数对PHP数组的键名进行排序,并且保留原来的索引关系。
usort通过自定义函数对PHP数组的键值进行排序,并且删除原来的索引关系,从零开始建立新的索引。
这个地方当然需要一个例子:
输出结果:
array(4) {
[0]=>
int(1)
[3]=>
int(5)
[1]=>
int(4)
[2]=>
int(3)
}
,呵呵……是不是比不排序还乱呢?我们这里只是演示了使用的方法而已,具体你用到的时候自己搞吧!你要是不对这些数值进行操作之后再比较,例如我们这里:
$a+=1;
$b+=3;//改变这些值之后进行比较
在PHP手册中,一共定义了74个数组函数,涵盖了PHP数组的定义,赋值,排序,数值操作,比较,以及对数组的键名,键值反转……等等我们几乎能够想到的所有功能。有需要的同学可以去参考一下啊