<?php
$data = [
[
"id" => 1,
"influencer_user_id" => 4,
"content_data" => '{"Reach":"300","Views":"320","Views through rate":"350","Shares":"350"}',
],
[
"id" => 2,
"influencer_user_id" => 4,
"content_data" => '{"Reach":"100","Likes":"100","Views":"100"}',
],
[
"id" => 3,
"influencer_user_id" => 5,
"content_data" => '{"Reach":"350"}',
],
];
$result = array();
// first, group the influencer_user_id
foreach ($data as $element) {
$result[$element['influencer_user_id']][] = $element;
}
// second, calculate content_data
$result = array_map(function($element){
$element = array_reduce($element, function($carry, $item){
// convert to array
$content_data = json_decode($item['content_data'], true);
// convert content_data to integer values
$content_data = array_map('intval', $content_data);
$item['content_data'] = $content_data;
if(empty($carry))
return $item;
// compute content_data sum
array_walk($item['content_data'], function(&$value, $key) use ($carry){
if(isset($carry['content_data'][$key])){
$value += $carry['content_data'][$key];
}
});
return $item;
});
// convert content_data back to json
$cdata = $element['content_data'];
$element['content_data'] = json_encode($cdata);
return $element;
}, $result);
$result = array_values($result);
print_r($result);
- Output for 7.1.25 - 7.1.33, 7.2.0 - 7.2.33, 7.3.0 - 7.3.33, 7.4.0 - 7.4.33, 8.0.0 - 8.0.30, 8.1.0 - 8.1.28, 8.2.0 - 8.2.18, 8.3.0 - 8.3.4, 8.3.6
- Array
(
[0] => Array
(
[id] => 2
[influencer_user_id] => 4
[content_data] => {"Reach":400,"Likes":100,"Views":420}
)
[1] => Array
(
[id] => 3
[influencer_user_id] => 5
[content_data] => {"Reach":350}
)
)
- Output for 8.3.5
- Warning: PHP Startup: Unable to load dynamic library 'sodium.so' (tried: /usr/lib/php/8.3.5/modules/sodium.so (libsodium.so.23: cannot open shared object file: No such file or directory), /usr/lib/php/8.3.5/modules/sodium.so.so (/usr/lib/php/8.3.5/modules/sodium.so.so: cannot open shared object file: No such file or directory)) in Unknown on line 0
Array
(
[0] => Array
(
[id] => 2
[influencer_user_id] => 4
[content_data] => {"Reach":400,"Likes":100,"Views":420}
)
[1] => Array
(
[id] => 3
[influencer_user_id] => 5
[content_data] => {"Reach":350}
)
)
preferences:
187.21 ms | 402 KiB | 178 Q