PHP:统计多维复杂数组中符合条件的元素数量

php:统计多维复杂数组中符合条件的元素数量

本文旨在提供一种在 PHP 中统计多维复杂数组中,根据特定条件(如 evaluator_row_id 和 settings_row_id)筛选并计算 questions_row_id 数量的方法。通过逐步解析数组结构,构建新的关联数组,并最终统计符合条件的元素个数,实现高效的数据分析。

在处理复杂的多维数组时,有时需要根据特定条件统计某些元素的数量。例如,给定一个包含问题、设置和评估者信息的数组,我们需要统计特定评估者和设置下问题的数量。本文将提供一种使用 PHP 实现此功能的有效方法。

数据结构分析

首先,我们需要理解输入数组的结构。它是一个三维数组,其中:

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

  • 第一层数组的索引没有特定含义。
  • 第二层数组只有一个元素,其索引也是没有特定含义。
  • 第三层数组包含三个键:questions_row_id、settings_row_id 和 evaluator_row_id。
    • questions_row_id 是问题的 ID。
    • settings_row_id 是设置的 ID。
    • evaluator_row_id 是一个数组,包含评估者的 ID。

实现步骤

  1. 构建新的关联数组

遍历原始数组,提取所需的信息,并构建一个新的关联数组,其结构如下:

   $evaluators[$evaluator_id][$settings_id][] = $questions_row_id;
登录后复制

其中,$evaluator_id 是评估者的 ID,$settings_id 是设置的 ID,$questions_row_id 是问题的 ID。这个新的数组将问题 ID 按照评估者和设置进行分组。

   $evaluators = [];

   // 开始遍历
   foreach ($myarray as $i1 => $set1) {
       foreach ($set1 as $i2 => $set2) {
           // 遍历每个评估者 ID
           foreach ($set2['evaluator_row_id'] as $evaluator_id) {
               // 构建新的数组,以评估者 ID 和设置 ID 为键
               $settings_id = $set2['settings_row_id'];
               $evaluators[$evaluator_id][$settings_id][] = $set2['questions_row_id'];
           }
       }
   }
登录后复制
  1. 统计问题数量

遍历新构建的关联数组,统计每个评估者和设置下问题的数量。

   $question_counts = [];
   foreach ($evaluators as $evaluator_id => $settings_list) {
       foreach ($settings_list as $setting_id => $question_ids) {
           $question_counts[$evaluator_id][$setting_id] = count($question_ids);
       }
   }
登录后复制

$question_counts 数组将包含每个评估者和设置组合的问题数量。

完整代码示例

<?php

$myarray = [
    0 => [
        0 => [
            "questions_row_id" => 1,
            "settings_row_id" => 1,
            "evaluator_row_id" => [
                0 => "1",
                1 => "4",
                2 => "101",
            ],
        ],
    ],
    1 => [
        0 => [
            "questions_row_id" => 2,
            "settings_row_id" => 1,
            "evaluator_row_id" => [
                0 => "1",
                1 => "100",
            ],
        ],
    ],
    2 => [
        0 => [
            "questions_row_id" => 4,
            "settings_row_id" => 3,
            "evaluator_row_id" => [
                0 => "1",
                1 => "101",
            ],
        ],
    ],
];

$evaluators = [];

// 开始遍历
foreach ($myarray as $i1 => $set1) {
    foreach ($set1 as $i2 => $set2) {
        // 遍历每个评估者 ID
        foreach ($set2['evaluator_row_id'] as $evaluator_id) {
            // 构建新的数组,以评估者 ID 和设置 ID 为键
            $settings_id = $set2['settings_row_id'];
            $evaluators[$evaluator_id][$settings_id][] = $set2['questions_row_id'];
        }
    }
}

$question_counts = [];
foreach ($evaluators as $evaluator_id => $settings_list) {
    foreach ($settings_list as $setting_id => $question_ids) {
        $question_counts[$evaluator_id][$setting_id] = count($question_ids);
    }
}

print_r($question_counts);

?>
登录后复制

代码输出

Array
(
    [1] => Array
        (
            [1] => 2
            [3] => 1
        )

    [4] => Array
        (
            [1] => 1
        )

    [101] => Array
        (
            [1] => 1
            [3] => 1
        )

    [100] => Array
        (
            [1] => 1
        )

)
登录后复制

注意事项

  • 确保输入数组的结构与代码中的假设一致。如果结构不同,可能需要修改代码以适应新的结构。
  • 此方法适用于处理相对较小的数据集。对于非常大的数据集,可能需要考虑使用更高效的算法或数据库查询。

总结

本文提供了一种使用 PHP 统计多维复杂数组中符合特定条件的元素数量的方法。通过构建新的关联数组,可以方便地对数据进行分组和统计。这种方法在处理需要根据多个条件筛选和分析数据的场景中非常有用。

以上就是PHP:统计多维复杂数组中符合条件的元素数量的详细内容,更多请关注php中文网其它相关文章!

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

发表回复

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