Isolieren Sie eindeutige Werte aus einer Spalte eines 2D -Arrays und gruppieren Sie andere Spalten in SubtarraysPhp

PHP-Programmierer chatten hier
Guest
 Isolieren Sie eindeutige Werte aus einer Spalte eines 2D -Arrays und gruppieren Sie andere Spalten in Subtarrays

Post by Guest »

Ich habe ein Array, das so aussieht: < /p>

Code: Select all

Array
(
[0] => Array
(
[amount] => 75.00
[name] => CLIENT1
[week] => 22
)

[1] => Array
(
[amount] => 945.00
[name] => CLIENT1
[week] => 23
)

[2] => Array
(
[amount] => 45.00
[name] => CLIENT1
[week] => 24
)
...

[15] => Array
(
[amount] => 45.00
[name] => CLIENTX
[week] => 22
)

[16] => Array
(
[amount] => 15.00
[name] => CLIENTX
[week] => 22
)
// HAS NO VALUE IN WEEK 23 BUT TWO IN WEEK 22!!!
[17] => Array
(
[amount] => 73.00
[name] => CLIENTX
[week] => 24
)
Ich brauche ein Array, das so aussieht

Code: Select all

Array
(
['weeks'] => Array (22,23,24) //ALL WEEKS FOUND SOMEWHERE
['series'] => Array
(
[0] => Array
(
['name'] => 'CLIENT1'
['data'] => Array (75.00, 945.00, 45.00)
)
[1] => Array
(
['name'] => 'CLIENTX'
['data'] => Array (60.00, 0, 73.00)
)
)
)
Versuchen Sie zuerst
Dies ist eher ein logisches Problem, nicht eine Frage der Programmierung, aber ich stecke beim Schauen fest So lange jetzt. . < /p>
Die Nächstes habe ich so weit gekommen: < /p>

Code: Select all

$clientArray = array();
$weekAmount = array();
foreach($hours as $hour){
/* For better readability */
$client = $hour['name'];
$amount = $hour['amount'];
$week = $hour['week'];

if(!array_key_exists($week, $weekAmount)){
$weekAmount[$week] = 0;
}
$weekAmount[$week] = $amount;
$clientArray[$client] = $weekAmount;
ksort($clientArray[$client]); // to order by weeks
}
, aber dies fügt die Werte aus derselben Woche nicht hinzu und ich muss dies noch einmal durchschlagen und ich weiß nicht, wie man die "fehlenden" Wochen findet und 0 als den nach Wert.

Quick Reply

Change Text Case: 
   
  • Similar Topics
    Replies
    Views
    Last post