2013-01-07 11 views
8

Więc mam ten asocjacyjną (zrzutu zrobić z kint)Tablica asocjacyjna, wartości sumy tego samego klucza

dump done with Kint d

zamiast przycisku „Conference” powtarzając 3 razy. Chcę mieć go tylko raz, a suma wartości 3 do jednego, aby mieć coś takiego:

Konferencja: 4534

I to samo dla wszystkich innych kluczy, które są powtarzających ..

Czy istnieje natywna funkcja, która może to zrobić?

Odpowiedz

24

Można spróbować

$data = array(
    0 => array(
    'event' => 'Conference', 
    'budget' => 3700, 
), 
    1 => array(
    'event' => 'Conference', 
    'budget' => 500, 
), 
    2 => array(
    'event' => 'Showroom', 
    'budget' => 1000, 
), 
    3 => array(
    'event' => 'Mission Chez client', 
    'budget' => 2000, 
), 
    4 => array(
    'event' => 'Séminaire', 
    'budget' => 700, 
), 
    5 => array(
    'event' => 'Livraison', 
    'budget' => 4000, 
), 
    6 => array(
    'event' => 'Conference', 
    'budget' => 334, 
), 
); 

$sum = array_reduce($data, function ($a, $b) { 
    isset($a[$b['event']]) ? $a[$b['event']]['budget'] += $b['budget'] : $a[$b['event']] = $b; 
    return $a; 
}); 


print_r(array_values($sum)); 

wyjściowy

Array 
(
    [0] => Array 
     (
      [event] => Conference 
      [budget] => 4534 
     ) 

    [1] => Array 
     (
      [event] => Showroom 
      [budget] => 1000 
     ) 

    [2] => Array 
     (
      [event] => Mission Chez client 
      [budget] => 2000 
     ) 

    [3] => Array 
     (
      [event] => Séminaire 
      [budget] => 700 
     ) 

    [4] => Array 
     (
      [event] => Livraison 
      [budget] => 4000 
     ) 

) 
+0

Zachowuje drugi klucz "budżet", ale nie pierwsze "zdarzenie", daje to: [link] (http://d.pr/i/7rKM) – Alucard

+0

Naprawdę muszę zachować tę samą strukturę, ale wartości sumy z tym samym kluczem – Alucard

+0

Zobacz Zaktualizowany kod – Baba

4

prosta sugestia:

$results = array(); 
foreach ($budgetByEventTemp as $value) 
{ 
    if(! isset($results[$value['event']])) 
    { 
    $results[$value['event']] = 0; 
    } 

    $results[$value['event']] += $value['budget']; 

} 

var_dump($results); 

Aktualizacja według uwag

można uruchomić na nich ponownie:

foreach($results as $key => $value) 
{ 
    $structured_results[] = array('event' => $key, 'budget' => $value); 
} 

var_dump($structured_results); 
+0

Dziękuję za sugestię, ale to nie byłoby zachować klucze tablicy (zdarzenie i budżet) – Alucard

+0

I nie rozumiem, dlaczego tak powinieneś, kiedy chcesz podsumować wartości? – Repox

+0

Ta tablica jest zakodowana przez json i wysłana do ugotowania gdzie indziej, więc muszę zachować tę samą strukturę i tylko sumy wartości z tym samym kluczem – Alucard

1
$sumArray = array(); 

foreach ($myArray as $k=>$subArray) { 
foreach ($subArray as $id=>$value) { 
    $sumArray[$id]+=$value; 
    } 
} 

print_r($sumArray); 
+0

To nie jest dobre - wygeneruje Powiadomienia. – mickmackusa

0

to opcja ta grupa a suma wartości wszystkich powtarzających indeksy w tablicy.

kod tutaj:

$aValues[]=array("nametogroup",10); 
$aValues[]=array("nametogroup",20); 
$aValues[]=array("nametogroup2",30); 
$aValues[]=array("nametogroup2",20); 
echo var_dump($aValues); // array before grouping 
foreach ($aValues as $id=>$value) 
{ 
    $a2sum["{$value[0]}"]=$value[1] + $a2sum["{$value[0]}"]; 
} 
echo var_dump($a2sum); //array after group and adding values 

Spowoduje do:

array 
0 => 
array 
    0 => string nametogroup (length=11) 
    1 => int 10 
1 => 
array 
    0 => string nametogroup (length=11) 
    1 => int 20 
2 => 
array 
    0 => string nametogroup2 (length=12) 
    1 => int 30 
3 => 
array 
    0 => string nametogroup2 (length=12) 
    1 => int 20 

array 
nametogroup => int 30 
nametogroup2 => int 50