0

有没有一种有效的方法来组合array_count_values($arr1)array_count_values($arr2)if的返回数组$arr1并且$arr2具有相同值的元素?

我正在尝试通过经典的“从包含 10 亿行搜索请求的文档中生成前 100 个搜索请求”。

我的方法是使用 unixsplit将文档分割成更小的文件,用 计算每个文件中每个搜索词的出现次数array_count_values,然后将所有这些文件减少到一个文件中,该文件的列表按每个搜索查询的流行度降序排列.

编辑 例如

$arr1 = array('kurt', 'curt', 'kurt', 'dave', 'krist');
$arr2 = array('dave' 'dave', 'krist', 'krist');

array_count_values($arr1) // ('kurt' => 2, 'curt'=>1, 'dave'=>1, 'krist'=>1)
array_count_values($arr2) // ('dave' => 2, 'krist'=>2)

如何将两者结合起来形成以下数组

('kurt' => 2, 'dave'=>3, 'krist'=>3, 'curt'=>1)
4

3 回答 3

1

试试这个 :

$arr1 = array('kurt', 'curt', 'kurt', 'dave', 'krist');
$arr2 = array('dave', 'dave', 'krist', 'krist');

$cnt_arr1  = array_count_values($arr1); // ('kurt' => 2, 'curt'=>1, 'dave'=>1, 'krist'=>1)
$cnt_arr2  = array_count_values($arr2); // ('dave' => 2, 'krist'=>2)

$res_arr   = array_merge_recursive($cnt_arr1,$cnt_arr2);

$res       = array();
foreach($res_arr as $key=>$val){
 if(is_array($val)){
    $res[$key]= array_sum($val);
 }else{
    $res[$key]= $val;
 }

}

echo "<pre>";
print_r($res);
于 2013-02-22T06:40:22.240 回答
0

试试这个 :

$arr = array_merge($arr1,$arr2);
$count = array_count_values($arr);
于 2013-02-22T06:22:59.703 回答
0

请尝试以下代码。它会工作,

$arr1 = array('kurt', 'curt', 'kurt', 'dave', 'krist');
$arr2 = array('dave', 'dave', 'krist', 'krist');

$array1Count = array_count_values($arr1); // ('kurt' => 2, 'curt'=>1, 'dave'=>1, 'krist'=>1)
$array2Count = array_count_values($arr2); // ('dave' => 2, 'krist'=>2)
$resultArray = array();
foreach($array1Count as $key => $value) {
    if(array_key_exists($key, $array2Count)) {
        $resultArray[$key] = $array1Count[$key] + $array2Count[$key];
    }
    else {
        $resultArray[$key] = $array1Count[$key];
    }
    unset($array2Count[$key]);
}
$finalResultArray = array_merge($array2Count, $resultArray);
print_r($finalResultArray);
于 2013-02-22T06:42:05.280 回答