
本文旨在讲解如何从PHP多维数组中提取特定条件下的最大值。通过迭代数组,并使用年份和月份作为唯一标识,我们可以有效地找出每个年份和月份组合对应的最大 pembetulan 值。最终,我们将得到一个包含每个年份和月份组合及其最大 pembetulan 值的新数组。
在处理PHP多维数组时,有时我们需要根据某些条件筛选出特定的数据。例如,我们可能需要从一个包含年份、月份和pembetulan值的数组中,找出每个年份和月份组合对应的最大pembetulan值。以下提供一种高效的解决方案。
实现方法
该方法的核心思想是:
立即学习“PHP免费学习笔记(深入)”;
- 创建临时键: 使用年份和月份组合成一个唯一的字符串作为临时键,用于标识不同的分组。
- 迭代数组: 遍历原始数组,对于每一行数据,检查临时键是否存在于结果数组中。
- 比较和更新: 如果临时键不存在,或者当前行的pembetulan值大于结果数组中对应键的pembetulan值,则将当前行保存到结果数组中。
- 移除临时键: 遍历完成后,移除结果数组中的临时键,得到最终的结果。
示例代码
<?php
$data = [
["tahun" => 2001, "bulan" => 1, "pembetulan" => 0],
["tahun" => 2002, "bulan" => 1, "pembetulan" => 0],
["tahun" => 2002, "bulan" => 1, "pembetulan" => 1],
["tahun" => 2003, "bulan" => 1, "pembetulan" => 0],
["tahun" => 2003, "bulan" => 1, "pembetulan" => 1],
["tahun" => 2003, "bulan" => 1, "pembetulan" => 2],
["tahun" => 2003, "bulan" => 1, "pembetulan" => 3],
["tahun" => 2003, "bulan" => 1, "pembetulan" => 4],
["tahun" => 2003, "bulan" => 2, "pembetulan" => 0]
];
$result = [];
foreach ($data as $row) {
$compositeKey = $row['tahun'] . '_' . $row['bulan'];
if (!isset($result[$compositeKey]) || $row['pembetulan'] > $result[$compositeKey]['pembetulan']) {
$result[$compositeKey] = $row;
}
}
$result = array_values($result); // 移除临时键
var_export($result);
?>
登录后复制
代码解释
- $data: 原始的多维数组。
- $result: 用于存储结果的数组。
- $compositeKey: 由年份和月份组成的临时键。
- isset($result[$compositeKey]): 检查结果数组中是否已存在该临时键。
- $row[‘pembetulan’] youjiankuohaophpcn $result[$compositeKey][‘pembetulan’]: 比较当前行的pembetulan值和结果数组中对应键的pembetulan值。
- array_values($result): 移除结果数组中的临时键,将结果数组的键重置为数字索引。
- var_export($result): 以可读的方式输出结果数组。
输出结果
array (
0 =>
array (
'tahun' => 2001,
'bulan' => 1,
'pembetulan' => 0,
),
1 =>
array (
'tahun' => 2002,
'bulan' => 1,
'pembetulan' => 1,
),
2 =>
array (
'tahun' => 2003,
'bulan' => 1,
'pembetulan' => 4,
),
3 =>
array (
'tahun' => 2003,
'bulan' => 2,
'pembetulan' => 0,
),
)
登录后复制
注意事项
- 如果原始数组为空,则结果数组也将为空。
- 如果多个年份和月份组合具有相同的最大pembetulan值,则只会保留第一个遇到的组合。
- 此方法适用于需要根据多个字段进行分组并提取最大值的情况。
总结
通过使用临时键和迭代比较,我们可以有效地从PHP多维数组中提取每个分组对应的最大值。这种方法简洁高效,适用于各种需要根据特定条件筛选数据的场景。 根据实际情况,可以灵活调整临时键的生成方式,以适应不同的数据结构和需求。
以上就是从PHP多维数组中提取每个年份和月份对应的最大pembetulan值的详细内容,更多请关注php中文网其它相关文章!


