首页 > 后端开发 > php教程 > 如何在 PHP 中按列值对多维数组行进行分组?

如何在 PHP 中按列值对多维数组行进行分组?

Mary-Kate Olsen
发布: 2024-12-18 10:14:12
原创
504 人浏览过

How to Group Multidimensional Array Rows by Column Value in PHP?

使用 PHP 按列值对数组行进行分组并形成子数组

按特定列值对多维数组中的行进行分组是一项常见任务在数据操作中。虽然没有内置的 PHP 函数可以直接实现此目的,但自定义循环可以根据所选列有效地对行进行分组。

考虑以下多维数组:

$array = [
    [
        'id' => 96,
        'shipping_no' => '212755-1',
        'part_no' => 'reterty',
        'description' => 'tyrfyt',
        'packaging_type' => 'PC',
    ],
    [
        'id' => 96,
        'shipping_no' => '212755-1',
        'part_no' => 'dftgtryh',
        'description' => 'dfhgfyh',
        'packaging_type' => 'PC',
    ],
    [
        'id' => 97,
        'shipping_no' => '212755-2',
        'part_no' => 'ZeoDark',
        'description' => 's%c%s%c%s',
        'packaging_type' => 'PC',
    ],
];
登录后复制

到按“id”列对数组进行分组,可以使用简单的 foreach 循环:

$result = [];
foreach ($array as $element) {
    $result[$element['id']][] = $element;
}
登录后复制

此循环迭代原始中的每个元素数组并将其存储在“结果”数组中,其中“id”值作为键。结果,“结果”数组将按“id”列分组:

Array
(
    [96] => Array
        (
            [0] => Array
                (
                    [id] => 96
                    [shipping_no] => 212755-1
                    [part_no] => reterty
                    [description] => tyrfyt
                    [packaging_type] => PC
                )
            [1] => Array
                (
                    [id] => 96
                    [shipping_no] => 212755-1
                    [part_no] => dftgtryh
                    [description] => dfhgfyh
                    [packaging_type] => PC
                )
        )
    [97] => Array
        (
            [0] => Array
                (
                    [id] => 97
                    [shipping_no] => 212755-2
                    [part_no] => ZeoDark
                    [description] => s%c%s%c%s
                    [packaging_type] => PC
                )
        )
)
登录后复制

以上是如何在 PHP 中按列值对多维数组行进行分组?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板