如何按值排序多维数组?

ste*_*tef 1058 php arrays sorting multidimensional-array

如何通过"order"键的值对此数组进行排序?尽管这些值目前是连续的,但它们并不总是如此.

Array
(
    [0] => Array
        (
            [hashtag] => a7e87329b5eab8578f4f1098a152d6f4
            [title] => Flower
            [order] => 3
        )

    [1] => Array
        (
            [hashtag] => b24ce0cd392a5b0b8dedc66c25213594
            [title] => Free
            [order] => 2
        )

    [2] => Array
        (
            [hashtag] => e7d31fc0602fb2ede144d18cdffd816b
            [title] => Ready
            [order] => 1
        )
)
Run Code Online (Sandbox Code Playgroud)

Chr*_*der 1624

尝试usort,如果你仍然在PHP 5.2或更早版本,你必须先定义一个排序函数:

function sortByOrder($a, $b) {
    return $a['order'] - $b['order'];
}

usort($myArray, 'sortByOrder');
Run Code Online (Sandbox Code Playgroud)

从PHP 5.3开始,您可以使用匿名函数:

usort($myArray, function($a, $b) {
    return $a['order'] - $b['order'];
});
Run Code Online (Sandbox Code Playgroud)

最后使用PHP 7,您可以使用太空船运营商:

usort($myArray, function($a, $b) {
    return $a['order'] <=> $b['order'];
});
Run Code Online (Sandbox Code Playgroud)

要将其扩展到多维排序,如果第一个为零,则引用第二个/第三个排序元素 - 下面将对此进行最佳说明.您还可以使用它来对子元素进行排序.

usort($myArray, function($a, $b) {
    $retval = $a['order'] <=> $b['order'];
    if ($retval == 0) {
        $retval = $a['suborder'] <=> $b['suborder'];
        if ($retval == 0) {
            $retval = $a['details']['subsuborder'] <=> $b['details']['subsuborder'];
        }
    }
    return $retval;
});
Run Code Online (Sandbox Code Playgroud)

如果需要保留关键关联,请使用uasort()- 请参阅手册中数组排序功能的比较

  • Protip:如果要保留数组键,请使用`uasort()`. (57认同)
  • 我花了一段时间才发现.要对相反顺序(DESC)进行排序,您可以切换$ a和$ b.所以$ b ['order'] - $ a ['order'] (31认同)
  • @Jonathan:你无法真正看到PHP的大部分工作.它接受数组并从两个元素开始,它传递给这个用户定义的函数.然后你的函数负责比较它们:如果第一个元素大于第二个元素,则返回一个正整数,如果它小,则返回一个负整数.如果它们是equel,则返回0. PHP然后将另外两个元素发送到您的函数并继续这样做,直到数组已经排序.这里的函数非常短,如果你不比较整数,它可能会复杂得多. (22认同)
  • 如果可排序值是十进制数,请小心.如果排序函数得到$ a = 1和$ b = 0.1,则差值为0.9,但函数返回一个int,在本例中为0,因此$ a和$ b被认为是相等的并且排序不正确.如果$ a大于$ b或相等,则比较更可靠,并相应地返回-1,1或0. (15认同)
  • 我的措辞有点偏,我会编辑它.我的意思是,如果你没有使用PHP 5.3,你需要为这个特定的排序创建一个特殊的功能(这在某种程度上不是很优雅).否则你可以在那里使用匿名函数. (2认同)
  • 这很好用,我有一个多维数组来排序.这非常好!这就是我用它的方式`usort($ subArray,function($ b,$ a){return $ a ['c'] [5] ['v'] - $ b ['c'] [5] [' v'];});` (2认同)
  • 太空船操作员+1 (2认同)

o0'*_*0'. 278

function aasort (&$array, $key) {
    $sorter=array();
    $ret=array();
    reset($array);
    foreach ($array as $ii => $va) {
        $sorter[$ii]=$va[$key];
    }
    asort($sorter);
    foreach ($sorter as $ii => $va) {
        $ret[$ii]=$array[$ii];
    }
    $array=$ret;
}

aasort($your_array,"order");
Run Code Online (Sandbox Code Playgroud)

  • @ noc2spam我很乐意提供帮助,但请考虑遵循[studer的建议](http://stackoverflow.com/a/2699159/207655),这可能更有效,更肯定更整洁! (7认同)
  • 比上面的答案更容易申请 (3认同)
  • 这个答案缺少其教育解释。 (3认同)

Tom*_*igh 263

我用这个函数:

function array_sort_by_column(&$arr, $col, $dir = SORT_ASC) {
    $sort_col = array();
    foreach ($arr as $key=> $row) {
        $sort_col[$key] = $row[$col];
    }

    array_multisort($sort_col, $dir, $arr);
}


array_sort_by_column($array, 'order');
Run Code Online (Sandbox Code Playgroud)

  • 效果很好.唯一的解决方案是能够添加排序方向.谢谢! (3认同)
  • 对于支持排序方向和许多其他功能的替代方案,您可能需要查看[我的答案](http://stackoverflow.com/a/16788610/50079) - 它还具有以下优势:它不使用`array_multisort`,因此不需要预先分配`$ sort_col`,节省了时间和内存. (2认同)
  • @RaduMurzea所以数组是通过引用传递的,可以通过函数修改,而不是接收副本的函数 (2认同)

Jan*_*bry 68

我通常使用usort,并传递我自己的比较函数.在这种情况下,它非常简单:

function compareOrder($a, $b)
{
  return $a['order'] - $b['order'];
}
usort($array, 'compareOrder');
Run Code Online (Sandbox Code Playgroud)

  • 啊.好.我使用的是非逻辑运算,你头脑中的想法与你产生的单词不匹配.星期五下午最常研究这种情况. (25认同)
  • 该死,我慢了30秒.不是$ a - $ b虽然? (4认同)
  • 我总是弄错了.让我从手册中思考:如果第一个参数被认为小于第二个参数,则返回值必须小于零.因此,如果`$ a ['order']`是3,而'$ b ['order']`是6,我将返回-3.正确? (3认同)
  • 好吧,你返回b - a,所以它将是3.因此排序不正确. (3认同)
  • @Meas 对于 DESC 排序,可以反转“a”和“b”相对于“&lt;=&gt;”的位置。请参阅[此答案](/sf/answers/3825305431/)。 (3认同)

aju*_*o91 33

实现这一目标的一种方法是这样的

    $new = [
              [
                'hashtag' => 'a7e87329b5eab8578f4f1098a152d6f4',
                'title' => 'Flower',
                'order' => 3,
              ],

              [
                'hashtag' => 'b24ce0cd392a5b0b8dedc66c25213594',
                'title' => 'Free',
                'order' => 2,
              ],

              [
                'hashtag' => 'e7d31fc0602fb2ede144d18cdffd816b',
                'title' => 'Ready',
                'order' => 1,
              ],
    ];

    $keys = array_column($new, 'order');

    array_multisort($keys, SORT_ASC, $new);

    var_dump($new);
Run Code Online (Sandbox Code Playgroud)

结果:

    Array
    (
        [0] => Array
            (
                [hashtag] => e7d31fc0602fb2ede144d18cdffd816b
                [title] => Ready
                [order] => 1
            )

        [1] => Array
            (
                [hashtag] => b24ce0cd392a5b0b8dedc66c25213594
                [title] => Free
                [order] => 2
            )

        [2] => Array
            (
                [hashtag] => a7e87329b5eab8578f4f1098a152d6f4
                [title] => Flower
                [order] => 3
            )

    )
Run Code Online (Sandbox Code Playgroud)

  • 虽然我喜欢了解太空飞船运算符,但这似乎是最容易理解和最直接的答案,其中包含 SORT_DESC 等有用选项和 sort_flags 的多个选项(https://www.php.net/manual/en/function.array-multisort.php) 。 (3认同)

Nit*_*dbz 16

$sort = array();
$array_lowercase = array_map('strtolower', $array_to_be_sorted);
array_multisort($array_lowercase, SORT_ASC, SORT_STRING, $alphabetically_ordered_array);
Run Code Online (Sandbox Code Playgroud)

这会处理大写和小写字母.

  • 这是如何回答按特定数组键排序的问题? (4认同)

B.K*_*B.K 12

要按"标题"键的值对数组进行排序,请使用:

uasort($myArray, function($a, $b) {
    return strcmp($a['title'], $b['title']);
});
Run Code Online (Sandbox Code Playgroud)

strcmp比较字符串.

uasort()维护定义的数组键.


Gui*_*ips 9

正如接受的答案所述,您可以使用:

usort($myArray, function($a, $b) {
    return $a['order'] <=> $b['order'];
});
Run Code Online (Sandbox Code Playgroud)

如果您需要按多列排序,那么您将执行以下操作:

usort($myArray, function($a, $b) {
    return [$a['column1'],$a['column2']] <=> [$b['column1'],$b['column2']];
});
Run Code Online (Sandbox Code Playgroud)

这可以扩展到数据中的任意数量的列。这依赖于您可以在 PHP 中直接比较数组的事实。在上面的示例中,数组将首先按 排序column1,然后按 排序column2。但您可以按任何顺序对列进行排序,例如:

usort($myArray, function($a, $b) {
    return [$a['column2'],$a['column1']] <=> [$b['column2'],$b['column1']];
});
Run Code Online (Sandbox Code Playgroud)

如果您需要对一列进行升序排序,对另一列进行降序排序,请将降序列交换到运算符的另一侧<=>

usort($myArray, function($a, $b) {
    return [$a['column1'],$b['column2']] <=> [$b['column1'],$a['column2']];
});
Run Code Online (Sandbox Code Playgroud)


Gha*_*iya 7

使用array_multisort(),array_map()

array_multisort(array_map(function($element) {
      return $element['order'];
  }, $array), SORT_ASC, $array);

print_r($array);
Run Code Online (Sandbox Code Playgroud)

演示


dıl*_*ücü 7

PHP 7.4及更高版本的工作“箭头函数”语法:

uasort($yourArray, fn($a, $b) => $a['order'] <=> $b['order']);

Run Code Online (Sandbox Code Playgroud)

漂亮的印刷品

echo '<pre>';
print_r($yourArray);
Run Code Online (Sandbox Code Playgroud)


Min*_*ork 6

最灵活的方法是使用这种方法:

Arr::sortByKeys(array $array, $keys, bool $assoc = true): array
Run Code Online (Sandbox Code Playgroud)

原因如下:

  • 您可以按任何键排序(也可以嵌套,例如'key1.key2.key3'['k1', 'k2', 'k3']

  • 它适用于关联数组和非关联数组($assoc标志)

  • 它不使用引用 - 它返回一个新的排序数组

在你的情况下,它会很简单:

$sortedArray = Arr::sortByKeys($array, 'order');
Run Code Online (Sandbox Code Playgroud)

这个方法是这个库的一部分。


归档时间:

查看次数:

758415 次

最近记录:

6 年,2 月 前