PHP 数组分组函数在统计分析中的应用

2024年 5月 2日 69.5k 0

使用 php 的 array_group_by() 函数可以对数组中的数据进行分组,从而方便进行统计分析,包括:分组后,可以通过 array_map() 函数计算每个组中的元素数量。还可以通过自定义回调函数找出每个组中具有最大值的元素。通过分组,可以进行实战案例应用,例如计算商品订单数据中每个产品组的总销售额。

PHP 数组分组函数在统计分析中的应用

PHP 数组分组函数在统计分析中的应用

在进行统计分析时,经常需要对数组中的数据进行分组和统计。PHP 提供了强大的数组分组函数 array_group_by(),可以轻松地根据指定键对数组进行分组。

array_group_by() 用法

array_group_by() 函数接受两个参数:

  • 数组: 要进行分组的数组。
  • 键选择器: 一个闭包或字符串函数,用于返回每个数组元素要分组的键。

函数返回一个分组后的数组,键是按键选择器计算的键,值是被分组的数组元素。

示例:

分组以下学生数组按性别:

$students = [
    ['id' => 1, 'name' => 'Alice', 'gender' => 'F'],
    ['id' => 2, 'name' => 'Bob', 'gender' => 'M'],
    ['id' => 3, 'name' => 'Carol', 'gender' => 'F'],
];

$genderGrouped = array_group_by($students, 'gender');

结果:

[
    'F' => [
        ['id' => 1, 'name' => 'Alice', 'gender' => 'F'],
        ['id' => 3, 'name' => 'Carol', 'gender' => 'F'],
    ],
    'M' => [
        ['id' => 2, 'name' => 'Bob', 'gender' => 'M'],
    ],
]

统计分析应用

使用 array_group_by() 进行分组后,可以使用其他函数对分组后的数组进行统计分析。例如:

频率计数: 计算每个组中元素的数量:

$genderCounts = array_map('count', $genderGrouped);

最大值: 查找每个组中具有最大值的元素:

$maxAgeByGender = array_map(function($group) {
    return max($group, function($a, $b) {
        return $a['age'] - $b['age'];
    });
}, $ageGrouped);

实战案例

以下是一个实战案例,演示如何使用 array_group_by() 对商品订单数据进行分组并计算每个产品组的总销售额:

$orders = [
    ['product_id' => 1, 'quantity' => 2, 'price' => 10],
    ['product_id' => 2, 'quantity' => 1, 'price' => 15],
    ['product_id' => 1, 'quantity' => 3, 'price' => 10],
];

// 按产品 ID 分组
$groupedByProduct = array_group_by($orders, 'product_id');

// 计算每个组的总销售额
$productSales = array_map(function($group) {
    return array_reduce($group, function($carry, $item) {
        return $carry + ($item['quantity'] * $item['price']);
    }, 0);
}, $groupedByProduct);

结果:

[
    1 => 50, // 总销售额为 $50 的产品 1
    2 => 15, // 总销售额为 $15 的产品 2
]

以上就是PHP 数组分组函数在统计分析中的应用的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!

相关文章

JavaScript2024新功能:Object.groupBy、正则表达式v标志
PHP trim 函数对多字节字符的使用和限制
新函数 json_validate() 、randomizer 类扩展…20 个PHP 8.3 新特性全面解析
使用HTMX为WordPress增效:如何在不使用复杂框架的情况下增强平台功能
为React 19做准备:WordPress 6.6用户指南
如何删除WordPress中的所有评论

发布评论