我正在创建一个分面搜索,并尝试使用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_reduce
与array_intersect
结合使用,将可变数量的数组减少到一个。
您可以使用array_combine()
将这些数组转换为名为$total_array
的单个数组,则使用CCD_ 11。我希望这个有用的