Reputation: 57
I'm creating a large array of info ready to be exported as a csv.
I'm having trouble adding additional items to the array.
I've looked at the php manual and loads of other resources, but I'm unable to get it to work?
All the work is done in my controller
public function payments_export()
{
$parents = $this->Swim_model->CRUD_read_parents();
foreach ($parents->result() as $parentsrow)
{
if($parentsrow->AdultID > 1000010)
{
$data[] = array(
'First Name' => $parentsrow->AdultFirstName,
'Surname' => $parentsrow->AdultLastName,
'Email' => $parentsrow->EmailName,
);
Lots more processing to produce $owes
$owes = number_format(array_sum($children) - $autodiscount, 2);
if($owes != 0)
{
$data['Fees'] = $owes;
}
}
}
So I create the array $data and store three bits of info in it - lots of processing later produces $owes (which is correct), but when I try to add it to the same row in the array, it doesn't?
The foreach loop should then go through each parent and add another row to the array containing the four items on each row.
Upvotes: 0
Views: 1868
Reputation: 473
Your $data array is multidimensional and to add to a specific part of it you would need to know the index. Try this:
public function payments_export()
{
$parents = $this->Swim_model->CRUD_read_parents();
$i = 0;
foreach ($parents->result() as $parentsrow)
{
if ($parentsrow->AdultID > 1000010)
{
$data[] = array(
'First Name' => $parentsrow->AdultFirstName,
'Surname' => $parentsrow->AdultLastName,
'Email' => $parentsrow->EmailName,
);
$owes = number_format(array_sum($children) - $autodiscount, 2);
if($owes != 0)
{
$data[$i]['Fees'] = $owes;
}
$i++;
}
}
}
Upvotes: 1
Reputation: 4821
Everytime you do the loop, you redefine $data['Fees']
. Think of it like this.
$data['Fees'] = 5;
echo $data['Fees']; // 5
$data['Fees'] = 3;
echo $data['Fees']; // 3
What you want is to add ['Fees'] as the value for the most recent element. Not tested, but something like this should get you the last element.
array_push($data[count($data)-1]['Fees'], $owes);
Upvotes: 0