繁体   English   中英

比较2个PHP数组并过滤掉结果

[英]Compare 2 PHP arrays and filter out results

我现在已经挣扎了一段时间。 我有2个阵列,我想彼此比较。 用户数组和课程数组。 课程数组中的键是该课程的ID

课程数组:

Array(
    // The key in this array ([143] or [13]) is the lesson ID each lesson contains one ore more topics
    [143] => Array (
        [0] => 315 // example: 315 is a topic ID within lesson 143
        [1] => 311
        [2] => 176
        [3] => 145
    )

    [13] => Array (
        [0] => 27
        [1] => 25
    )
)

用户数组仅包含有关用户已完成的主题的信息。 此数组中不存在未完成课程ID的主题。

主要问题:我想比较用户数组的主题ID和Lesson数组。 我想把未完成的主题放在一个单独的数组中。

用户数组

Array (
    [0] => Array (
        [143] => Array (
            [145] => 1 // (this 1 means it is completed, this key is a topic ID)
            [176] => 1
        )
    )

    [1] => Array (
        [13] => Array (
            [25] => 1
        )
    )

)

在上面的这个例子中,我想得到的结果是一个非匹配id的数组,如:

$result = array( 143 => array(311,315), 13 => array(27))

我希望它有点清楚。

如果有人能指出我正确的方向,我会很高兴! 我尝试了很多东西,但是把它们全部发布在这里它并没有澄清主要问题。

你必须使用array_keysarray_diff 在线编译我的回答

数组

$lesson = array(
    "143" => array("315", "311", "176", "145"),
    "13" => array("27", "25")
);

$user = array(
    array("143" => array("145" => "1", "176" => "1")),
    array("13" => array("25" => "1"))
);

机制/过程

$result = array();
foreach ($user as $key => $value) {
    foreach ($value as $key2 => $value2) {
        $result[$key2] = array_diff($lesson[$key2], array_keys($value2));
    }
}

结果

echo '<pre>';
print_r($result);
echo '</pre>';

产量

Array
    (
        [143] => Array
        (
            [0] => 315
            [1] => 311
        )
        [13] => Array
        (
            [0] => 27
        )
)

我要做的第一件事是使用可能的array_flip()来修改User数组,这样我最终会得到这样的结果:

Array (
   [0] => Array (

            [143] => Array (
                [0] => 145
                [1] => 176
            )

   )

   [1] => Array (

            [13] => Array (
                [0] => 25
            )

   )

一旦完成,你所要做的就是使用array_diff()函数来比较两个数组,你将只有第一个数组中的元素:

$diff = array_diff($lesson[143], $user[0][143])

我希望这有帮助。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM