Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Cложить многомерный массив по id

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Описание: Cложить многомерный массив по id и подсчитать сумму сложенных id
Alexey_php
Отправлено: 15 Сентября, 2016 - 17:28:08
Post Id


Новичок


Покинул форум
Сообщений всего: 17
Дата рег-ции: Янв. 2015  


Помог: 0 раз(а)




Здравствуйте.

Имею ассоциативный массив. (Вывод не из базы а то GROUP BY id)

Вот такого вида
PHP:
скопировать код в буфер обмена
  1. (
  2.     [0] => Array
  3.         (
  4.             [id] => 3
  5.             [name] => Ракета
  6.             [price] => 1257.14285714
  7.         )
  8.  
  9.     [1] => Array
  10.         (
  11.             [id] => 3
  12.             [name] => Ракета
  13.             [price] => 1680.00000000
  14.         )
  15.  
  16.     [2] => Array
  17.         (
  18.             [id] => 1
  19.             [name] => Шатл
  20.             [price] => 1232.00000000
  21.         )
  22.  
  23. )


Делаю так

PHP:
скопировать код в буфер обмена
  1. foreach($main_array AS $val)
  2. {
  3. $array[$val['id']] = array('id' => $val['id'], 'name' => $val['name'], 'price' => $val['price']);      
  4. }


встал на сложении внутри массива, так как хочу получить вот такой вид не используя 2 шт. foreach


PHP:
скопировать код в буфер обмена
  1. (
  2.     [3] => Array
  3.         (
  4.             [id] => 3
  5.             [name] => Ракета
  6.             [price] => 2937,14285714 (Сложение двух ID = 3)
  7.         )
  8.  
  9.     [1] => Array
  10.         (
  11.             [id] => 1
  12.             [name] => Шатл
  13.             [price] => 1232.00000000
  14.         )
  15.  
  16. )

(Отредактировано автором: 15 Сентября, 2016 - 17:32:01)

 
 Top
T1grOK
Отправлено: 15 Сентября, 2016 - 23:00:13
Post Id



Частый гость


Покинул форум
Сообщений всего: 129
Дата рег-ции: Июнь 2013  


Помог: 7 раз(а)




PHP:
скопировать код в буфер обмена
  1. foreach($main_array AS $val)
  2. {
  3.   if(!isset($array[$val['id']])){
  4.     $array[$val['id']] = $val;
  5.     continue;
  6.   }
  7.   $array[$val['id']]['price'] += $val['price'];      
  8. }

(Отредактировано автором: 15 Сентября, 2016 - 23:00:36)



-----
Mysql, Postgresql, Redis, Memcached, Unit Testing, CI, Kohana, Yii, Phalcon, Zend Framework, Joomla, Open Cart, Ymaps, VK Api
 
 Top
Alexey_php
Отправлено: 15 Сентября, 2016 - 23:07:51
Post Id


Новичок


Покинул форум
Сообщений всего: 17
Дата рег-ции: Янв. 2015  


Помог: 0 раз(а)




Нашёл вот что

PHP:
скопировать код в буфер обмена
  1.         $result = array_reduce($row, function($v, $i)
  2.         {
  3.                 if(isset($v[$i['id']]))
  4.                 {
  5.                         $v[$i['id']]['price'] += $i['price'];
  6.                 }
  7.                 else
  8.                 {
  9.                         $v[$i['id']] = $i;     
  10.                 }
  11.                 return $v;
  12.         }, array());


T1grOK твой код краше спасибо.

А вывод то, все равно 2 foreach есть

PHP:
скопировать код в буфер обмена
  1. foreach($row AS $val)
  2. {
  3.         if(!isset($array[$val['id']]))
  4.         {
  5.                 $array[$val['id']] = $val;
  6.                 continue;
  7.         }
  8.         $array[$val['id']]['price'] += $val['price'];
  9. }
  10.  
  11. foreach($array AS $key => $val)
  12. {
  13.         echo $val['id'].' - '.$val['name'].' - '.$val['price'].'<br>';
  14. }


Вопрос остался открытым, возможно ли 1 шт. foreach сделать сложение

(Отредактировано автором: 16 Сентября, 2016 - 00:21:10)

 
 Top
Ch_chov
Отправлено: 16 Сентября, 2016 - 14:19:39
Post Id



Постоянный участник


Покинул форум
Сообщений всего: 2121
Дата рег-ции: Июль 2008  
Откуда: из города


Помог: 90 раз(а)




Цитата:
Вопрос остался открытым, возможно ли 1 шт. foreach сделать сложение

И так 1 шт. потому что второй foreach к сложению не относится.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB