array_与可变数量的数组相交


array_intersect a variable amount of arrays

我正在创建一个分面搜索,并尝试使用array_intersect来比较数组并找到匹配的输入。

问题是,根据用户选择的过滤器,我随时都会有可变数量的阵列:

$array_1, $array_2, $array_3等…

如何创建一个在这个意义上是动态的array_intersect函数?

这就是我尝试过的:

$next_array = 0;
for($i = 0; $i < $array_count; $i++) {
    $next_array++;
    if ($i == 0) {
        $full_array = ${array_.$i};
    } else {
        if(!empty(${cvp_array.$next_array})) {
            $full_array = array_intersect($full_array, ${cvp_array_.$next_array});
        }
    }
}

-------------编辑---------------

我会尽量缩小我的目标:

如果用户点击三个过滤器,这将导致创建三个阵列,每个阵列都有单独的结果:

Array_1 ( [0] => 2, [1] => 4, [2] => 6 )

Array_2 ( [0] => 1, [1] => 4, [2] => 6 )

Array_3 ( [0] => 6, [1] => 7, [2] => 8 )

我需要能找到所有数组中的数字的代码。如果没有公共数字,那么它就会以false或其他什么结束。在上面的情况下,我需要它来检索6。如果它只是前两个数组,它将返回4和6。

试试这个:

$fullArray = array($array1, $array2, $array3...);
call_user_func_array('array_intersect', $fullArray);

可以使用:

$intersect = array_intersect(...$fullArray);

首先,将这些数组转换为数组数组。然后,可以将array_reducearray_intersect结合使用,将可变数量的数组减少到一个。

您可以使用array_combine()将这些数组转换为名为$total_array的单个数组,则使用CCD_ 11。我希望这个有用的