我有一个字符串索引数组,我需要部分排序。也就是说,必须先移动一些元素,但其他元素应保持其当前(php内部)顺序不变:
# The element with key "c" should be first
$foo = array(
"a" => 1,
"b" => 2,
"c" => 3,
"d" => 4,
);
uksort($foo, function ($a, $b) {
if ($a === "c") {
return -1;
} elseif ($b === "c") {
return 1;
}
return 0;
});
var_dump($foo);
我所期望的:
array(4) { ["c"]=> int(3) ["a"]=> int(1) ["b"]=> int(2) ["d"]=> int(4) }
//--------------------------^ "a" remains first of the unsorted ones
我得到了什么:
array(4) { ["c"]=> int(3) ["d"]=> int(4) ["b"]=> int(2) ["a"]=> int(1) }
//--------------------------^ "d" moved above "a"
这似乎是由于uksort()
内部使用的排序算法,它破坏了元素的脆弱顺序。还有其他的方法来完成这个排序吗?
对于此任务使用任何 sort
函数都是多余的。您只需要将输入数组合并为一个单独的数组,其中包含应该首先出现的元素。数组联合运算符(+
)可以很好地用于关联数组(否则array_merge()
也可以)。
代码(演示):
如果键c保证存在:
$foo = array(
"a" => 1,
"b" => 2,
"c" => 3,
"d" => 4,
);
$foo = ['c' => $foo['c']] + $foo;
var_export($foo);
如果键c可能不存在,请先检查是否存在:
$bar = array(
"a" => 1,
"b" => 2,
"d" => 4,
);
if (array_key_exists('c', $bar)) {
$bar = ['c' => $bar['c']] + $bar;
}
var_export($bar);
输出:array (
'c' => 3,
'a' => 1,
'b' => 2,
'd' => 4,
)
和
array (
'a' => 1,
'b' => 2,
'd' => 4,
)
这对我有效,返回:
array(4) { ["c"]=> int(3) ["a"]=> int(1) ["b"]=> int(2) ["d"]=> int(4) }
<?php
# The element with key "c" should be first
$foo = array(
"a" => 1,
"b" => 2,
"c" => 3,
"d" => 4,
);
uksort($foo, function ($a, $b) {
if ($a === "c") {
return -1;
} else
return 1;
});
var_dump($foo);
?>