我有两个关联数组:
ArrayA = array( [10] => ten
[12] => twelve
[22] => 10
[30] => 10, 12, 8
)
ArrayB = array( [10] => net
[12] => evlewt
[22] => 11, 12, 10
[30] => 10
)
需要比较两个阵列上相同键的值。某些键具有CSV值,并且可以位于两个阵列上。
例如,[22]
上的ArrayA
应在ArrayB
上以CSV格式进行检查。同样,[30]
中的ArrayB
应在ArrayA
上以CSV格式进行检查。其他人应该像往常一样进行比较==
注意:我试图避免在这里循环。我们当然可以通过Loop以多种方式实现这一点。我想知道是否有一种快速有效的方法来做到这一点而不需要循环。
编辑:为了进一步澄清,这就是如何比较这两者:
Is "ten" in ArrayA == "net" in ArrayB?
Is "twelve" in ArrayA == "evlewt" in ArrayB?
Is 10 in ArrayA existing in (11, 12, 10) of ArrayB?
Is (10, 12, 8) of ArrayA containing the 10 ArrayB?
答案 0 :(得分:2)
我希望我能正确理解这个问题。如果首先对数据进行标准化,则可以只比较数组
例如:
$a = array(
10 => 'net',
12 => 'evlewt',
22 => '10,12,11',
30 => '12,10'
);
$b = array(
10 => 'net',
12 => 'evlewt',
22 => '11,12,10',
30 => '12,10'
);
function normalize(&$value, $key) {
$value = explode(',', $value);
sort($value);
$value = implode(',', $value);
}
array_walk($a, 'normalize');
array_walk($b, 'normalize');
var_dump($a == $b); // outputs true
编辑:为了根据两个数组中的元素是否是另一个数组的子集来评估两个数组,我会将值规范化为数组并使用reduce_array()
函数。
<?php
$a = array(
10 => 'net',
12 => 'evlew',
22 => '10,12,11',
30 => '12,10,11'
);
$b = array(
10 => 'net',
12 => 'evlewt',
22 => '11,12,10',
30 => '12,10'
);
function normalize(&$value, $key) {
$value = explode(',', $value);
}
function compare_value($v, $w) {
if (false === $v) return false;
global $a, $b;
if(is_subset($a[$w], $b[$w]) || is_subset($b[$w], $a[$w]))
return true;
return false;
}
function is_subset($needle, $haystack) {
return count(array_intersect($needle, $haystack)) === count($needle);
}
array_walk($a, 'normalize');
array_walk($b, 'normalize');
$result = array_reduce(array_keys($a), 'compare_value', true);
var_dump($result); // outputs false
$a = array(
10 => 'net',
12 => 'evlewt',
22 => '10',
30 => '12,10,11'
);
$b = array(
10 => 'net',
12 => 'evlewt',
22 => '11,12,10',
30 => '12,10'
);
array_walk($a, 'normalize');
array_walk($b, 'normalize');
$result = array_reduce(array_keys($a), 'compare_value', true);
var_dump($result); // outputs true