如果这是一个非常基本的问题,请道歉。我无意中发现asort()
似乎适用于多维数组:
示例PHP
$animals = array(
1 => array('name' => 'Zebra'),
2 => array('name' => 'Fox'),
3 => array('name' => 'Rabbit'),
4 => array('name' => 'Dog'),
5 => array('name' => 'Cat')
);
asort($animals);
var_dump($animals);
输出
array
5 =>
array
'name' => string 'Cat' (length=3)
4 =>
array
'name' => string 'Dog' (length=3)
2 =>
array
'name' => string 'Fox' (length=3)
3 =>
array
'name' => string 'Rabbit' (length=6)
1 =>
array
'name' => string 'Zebra' (length=5)
我想知道为什么会有效?
我认为asort()
只排序了平面数组,并且需要定义自定义排序函数来对多维数组进行排序。我在文档中找不到解释上述行为的任何内容。
答案 0 :(得分:7)
数组在字典顺序中按其值进行比较,因此第一个元素为“cat”的数组小于第一个元素为“zebra”的数组。这只是一个正常的单维排序,恰好可以将数组相互比较。
例如:
php > var_dump(array('a')< array('b'));
bool(true)
php > var_dump(array('a')> array('b'));
bool(false)
答案 1 :(得分:3)
这是standard array comparison (在PHP中)的转录
<?php
// Arrays are compared like this with standard comparison operators
function standard_array_compare($op1, $op2)
{
if (count($op1) < count($op2)) {
return -1; // $op1 < $op2
} elseif (count($op1) > count($op2)) {
return 1; // $op1 > $op2
}
foreach ($op1 as $key => $val) {
if (!array_key_exists($key, $op2)) {
return null; // uncomparable
} elseif ($val < $op2[$key]) {
return -1;
} elseif ($val > $op2[$key]) {
return 1;
}
}
return 0; // $op1 == $op2
}
?>
这与你的案件一致
答案 2 :(得分:0)
PHP根据元素的数量比较数组,例如:具有一个元素的数组将被一起比较,并且将首先排序在顶部,然后,PHP查找类似的数组(基于元素的数量),然后将它们与彼此用于排序,等等,例如:
array(
a => array(z),
c => array(a,b),
d => array(d,r,3,4),
e => array(h,k,,p)
}
使用asort,结果将是
a => array(z)
将是第一个元素,因为没有其他数组包含一个元素,因此,它将在第一个位置分配。
array(
c => array(x,b),
e => array(h,k,,p)
a => array(z),
d => array(d,r,3,4),
}