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

PHP 数组分组函数在统计分析中的应用
在进行统计分析时,经常需要对数组中的数据进行分组和统计。PHP 提供了强大的数组分组函数 array_group_by(),可以轻松地根据指定键对数组进行分组。
array_group_by() 用法
立即学习“PHP免费学习笔记(深入)”;
array_group_by() 函数接受两个参数:
数组: 要进行分组的数组。键选择器: 一个闭包或字符串函数,用于返回每个数组元素要分组的键。
函数返回一个分组后的数组,键是按键选择器计算的键,值是被分组的数组元素。
示例:
分组以下学生数组按性别:
SpeakingPass-打造你的专属雅思口语语料
使用chatGPT帮你快速备考雅思口语,提升分数
25 查看详情
$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 数组分组函数在统计分析中的应用的详细内容,更多请关注php中文网其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/561654.html
微信扫一扫
支付宝扫一扫