November 30, 2016 —John Koster
sum($callback = null)
The sum
is a simple method that returns the sum of all items in a collection. It also defines a $callback
parameter which can be used to tell the sum
method which values of the collection should be added together. If no items are in the collection, the sum
method will return 0
.
The following code example shows the simplest way to use the sum
method:
1<?php 2 3use Illuminate\Support\Collection; 4 5// Create a new collection instance. 6$collection = new Collection([ 7 1, 2, 3, 4, 5 8]); 9 10// 1511$sum = $collection->sum();
After the above code has executed, the $sum
variable will contain the value 15
, which is indeed the sum of all the items in the collection.
The following is a more interesting example, and shows the total number of speakers at Laracon EU for the years 2013, 2014 and 2015. The number of speakers is not unique, and therefore not technically accurate:
1<?php 2 3use Illuminate\Support\Collection; 4 5// Create a new collection instance. 6$collection = new Collection([ 7 ['year' => '2015', 'speakers' => 12], 8 ['year' => '2014', 'speakers' => 21], 9 ['year' => '2013', 'speakers' => 10]10 11]);12 13// 4314$totalSpeakers = $collection->sum('speakers');
After the above code has executed, the $totalSpeakers
variable would contain the value 43
.
The following collection also contains the number of speakers that spoke Laracon EU from 2013 to 2015, but instead of representing the speakers as number, the collection contains lists the names of the speakers.
1<?php 2 3use Illuminate\Support\Collection; 4 5// Create a new collection instance. 6$collection = new Collection([ 7 [ 8 'year' => '2015', 9 'speakers' => [10 'Jeffrey',11 'Taylor',12 'Matt',13 'Konstantin',14 'Jessica',15 'Frank',16 'Adam',17 'Lorna',18 'Dries',19 'Ben',20 'Esther',21 'Hannes'22 ]23 ],24 [25 'year' => '2014',26 'speakers' => [27 'Taylor',28 'Ross',29 'Erika',30 'Konstantin',31 'Andreas',32 'Kayla',33 'Matthias',34 'Mathias',35 'Ben',36 'Rafael',37 'Igor',38 'Michelle',39 'Adam',40 'Xander',41 'Wim',42 'Mitchell',43 'Gabriela',44 'Matt',45 'Frank',46 'Hannes',47 'Kirk'48 ]49 ],50 [51 'year' => '2013',52 'speakers' => [53 'Taylor',54 'Fabien',55 'Phill',56 'Jordi',57 'Kapil',58 'Matthew',59 'Frank',60 'Jeffrey',61 'Ben',62 'Ross'63 ]64 ]65]);
The total number of speakers can be counted using the sum
method by passing a function as the argument to the $callback
parameter. The callback function passed must define one parameter, which will be the value of the item. The following code example shows how to get the sum of all the speakers in the above collection:
1<?php2 3// 434$totalSpeakers = $collection->sum(function($value) {5 return count($value['speakers']);6});
After the above code has executed, the value of $totalSpeakers
will be 43
, just as it was in the previous example. It is important to note that the callback function should return a numerical value, and in the above example it is returning the result of the count
function.
∎
The following amazing people help support this site and my open source projects ♥️
If you're interesting in supporting my work and want to show up on this list, check out my GitHub Sponsors Profile.