从PHP多维数组中提取每个年份和月份对应的最大pembetulan值

从php多维数组中提取每个年份和月份对应的最大pembetulan值

本文旨在讲解如何从PHP多维数组中提取特定条件下的最大值。通过迭代数组,并使用年份和月份作为唯一标识,我们可以有效地找出每个年份和月份组合对应的最大 pembetulan 值。最终,我们将得到一个包含每个年份和月份组合及其最大 pembetulan 值的新数组。

在处理PHP多维数组时,有时我们需要根据某些条件筛选出特定的数据。例如,我们可能需要从一个包含年份、月份和pembetulan值的数组中,找出每个年份和月份组合对应的最大pembetulan值。以下提供一种高效的解决方案。

实现方法

该方法的核心思想是:

立即学习PHP免费学习笔记(深入)”;

  1. 创建临时键: 使用年份和月份组合成一个唯一的字符串作为临时键,用于标识不同的分组。
  2. 迭代数组: 遍历原始数组,对于每一行数据,检查临时键是否存在于结果数组中。
  3. 比较和更新: 如果临时键不存在,或者当前行的pembetulan值大于结果数组中对应键的pembetulan值,则将当前行保存到结果数组中。
  4. 移除临时键: 遍历完成后,移除结果数组中的临时键,得到最终的结果。

示例代码

<?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);

?>
登录后复制

代码解释

Jasper

Jasper

Jasper是最高质量的AI文案工具

Jasper157


查看详情
Jasper

  • $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中文网其它相关文章!

https://www.php.cn/faq/1497028.html

发表回复

Your email address will not be published. Required fields are marked *