2017-03-20 189 views
0

我得到了一些數據集,它必須被映射,分組重複,像這樣:PHP數據映射

我:

<?php 
$var = array(
    array("Name" => "Alfred", "Number" => 1), 
    array("Name" => "Alfred", "Number" => 2), 
    array("Name" => "Alfred", "Number" => 3), 
    array("Name" => "Aethelstan", "Number" => 4), 
    array("Name" => "Aethelstan", "Number" => 5), 
    array("Name" => "Aethelstan", "Number" => 6), 
) 
?> 

我想將它更改爲:

<?php 
$var = array(
    array("name" => "Alfred","Number" => array(1,2,3)), 
    array("name" => "Aelthestan","Number" => array(4,5,6)), 
) 
?> 

有人有沒有很多循環和一對一比較的想法?

+1

如果名稱是有效的標識符,您可以創建一個數組,其中姓名是鍵,並且數字值的數組。如果不是,您可以使用散列函數,並將其用作關鍵字。 (並將名稱存儲在數組中)。 – Dan

回答

1

希望這會起作用。

PHP code demo

<?php 
$var = array(
    array("Name" => "Alfred", "Number" => 1), 
    array("Name" => "Alfred", "Number" => 2), 
    array("Name" => "Alfred", "Number" => 3), 
    array("Name" => "Aethelstan", "Number" => 4), 
    array("Name" => "Aethelstan", "Number" => 5), 
    array("Name" => "Aethelstan", "Number" => 6), 
); 
$result=array(); 
foreach($var as $value) 
{ 
    if(!isset($result[$value["Name"]])) 
    { 
     $result[$value["Name"]]=array("Name"=>$value["Name"],"Number"=>array($value["Number"])); 
    } 
    else 
    { 
     $result[$value["Name"]]["Number"][]=$value["Number"]; 
    } 

} 
$result=array_values($result); 
print_r($result); 

輸出:

Array 
(
    [0] => Array 
     (
      [Name] => Alfred 
      [Number] => Array 
       (
        [0] => 1 
        [1] => 2 
        [2] => 3 
       ) 

     ) 

    [1] => Array 
     (
      [Name] => Aethelstan 
      [Number] => Array 
       (
        [0] => 4 
        [1] => 5 
        [2] => 6 
       ) 

     ) 

) 
-1

可以在可能的解決方案:

<?php 
$var = array(
    array("Name" => "Alfred", "Number" => 1), 
    array("Name" => "Alfred", "Number" => 2), 
    array("Name" => "Alfred", "Number" => 3), 
    array("Name" => "Aethelstan", "Number" => 4), 
    array("Name" => "Aethelstan", "Number" => 5), 
    array("Name" => "Aethelstan", "Number" => 6), 
); 

$result = []; 
foreach ($var as $key => $value) { 
    if (!isset($result[$value['Name']])) { 
     $result[$value['Name']] =[]; 
    } 
    $result[$value['Name']][] = $value['Number']; 
} 

$final_result = []; 
foreach ($result as $key => $value) { 
    $final_result[] = ["name" => $key, "number" => $value]; 
} 

print_r($final_result); 
1

你也可以看看array_reduce了更多的功能/聲明/不可變的方法:

<?php 

$flatData = [ 
    ['name' => 'foo', 'number' => 1], 
    ['name' => 'foo', 'number' => 2], 
    ['name' => 'foo', 'number' => 3], 
    ['name' => 'bar', 'number' => 4], 
    ['name' => 'bar', 'number' => 5], 
    ['name' => 'bar', 'number' => 6], 
]; 

$treeData = array_reduce($flatData, function ($tree, $data) { 
    $key = $data['name']; 

    if (empty($tree[$key])) { 
    $tree[$key] = $data; 
    unset($tree[$key]['number']); 
    } 

    $tree[$key]['numbers'][] = $data['number']; 

    return $tree; 
}, []); 

print_r($treeData); 

https://repl.it/G4Cg