Wie GRUPPIEREN NACH und SUMME PHP Array?

Lesezeit: 2 Minuten

Benutzer-Avatar
Fawad Ghafoor

Wie man dieses Array gruppiert und summiert evaluation_category_id

Array
(
 [0] => Array
    (
        [id] => 60
        [evaluation_category_id] => 3
        [score] => 15
        [itemMaxPoint] => 20
    )
 [1] => Array
    (
        [id] => 61
        [evaluation_category_id] => 2
        [score] => 10
        [itemMaxPoint] => 20
    )

 [2] => Array
    (
        [id] => 62
        [evaluation_category_id] => 1
        [score] => 5
        [itemMaxPoint] => 20
    )

  [3] => Array
    (
        [id] => 63
        [evaluation_category_id] => 1
        [score] => 50
        [itemMaxPoint] => 200
    )

  [4] => Array
    (
        [id] => 64
        [evaluation_category_id] => 2
        [score] => 150
        [itemMaxPoint] => 200
    )

  [5] => Array
    (
        [id] => 65
        [evaluation_category_id] => 3
        [score] => 30
        [itemMaxPoint] => 50
    )
    .
    .
    .
 )

Damit ich ein Array wie dieses bekomme

 Array
  (
   [0] => Array
      (

    [evaluation_category_id] => 3
    [score] => 45
    [itemMaxPoint] => 70
   )

   [1] => Array
      (
    [evaluation_category_id] => 2
    [score] => 160
    [itemMaxPoint] => 220
   )

   [2] => Array
      (
    [evaluation_category_id] => 1
    [score] => 55
    [itemMaxPoint] => 220
   )
} 

Ich habe das versucht, aber es funktioniert nicht. Bitte korrigieren Sie mich, wo ich falsch mache

 public function test($data) {
    $groups = array();
    foreach ($data as $item) {
        $key = $item['evaluation_category_id'];
        if (!isset($groups[$key])) {
            $groups[$key] = array(
                'id' => $key,
                'score' => $item['score'],
                'itemMaxPoint' => $item['itemMaxPoint'],
            );
        } else {
            $groups[$key]['score'] = $groups[$key]['score'] + $item['score'];
            $groups[$key]['itemMaxPoint'] = $groups[$key]['itemMaxPoint'] +$item['itemMaxPoint'];
        }
    }
    return $groups;
}

die Ausgabe ist

Array
(
 [2] => Array
    (
        [id] => 2
        [score] => 121 //121 because the given array is different.but its actually SUM all values of score
        [itemMaxPoint] => 300
    )

)

  • Was hast du versucht? Siehe bitte um Rat fragen.

    – John Conde

    6. Februar 2013 um 17:15 Uhr

  • Schleife darüber und erstelle ein neues Array

    – Mike B

    6. Februar 2013 um 17:20 Uhr

  • mögliches Duplikat von Gruppieren von Arrays in PHP

    – Brent Washburne

    18. Juni 2015 um 17:17 Uhr

Benutzer-Avatar
Fawad Ghafoor

Ich habe es gelöst.

public function getDateWiseScore($data) {
    $groups = array();
    foreach ($data as $item) {
        $key = $item['evaluation_category_id'];
        if (!array_key_exists($key, $groups)) {
            $groups[$key] = array(
                'id' => $item['evaluation_category_id'],
                'score' => $item['score'],
                'itemMaxPoint' => $item['itemMaxPoint'],
            );
        } else {
            $groups[$key]['score'] = $groups[$key]['score'] + $item['score'];
            $groups[$key]['itemMaxPoint'] = $groups[$key]['itemMaxPoint'] + $item['itemMaxPoint'];
        }
    }
    return $groups;
}

Sie könnten eine Foreach durchführen, Arrays für gleiche Schlüssel generieren und dann array_sum() für jeden der Array-Werte, die Sie summieren möchten 🙂

1019100cookie-checkWie GRUPPIEREN NACH und SUMME PHP Array?

This website is using cookies to improve the user-friendliness. You agree by using the website further.

Privacy policy