JSON - суммировать значения по дате с использованием php

Я создаю простой скрипт на php и json, однако у меня есть некоторые трудности с суммированием нескольких значений по дате. Я хочу, чтобы сумма «Импорт» и «Экспорт» с каждого месяца.

Вот что я хочу напечатать:

array (
  'Date'   => '2019-03',
  'Import' => 1000,
  'Export' => 250,
)
array (
  'Date'   => '2019-04',
  'Import' => 100,
  'Export' => 600,
)

Мой json:

[
  {
    "Date": "2019-03",
    "Import": "200",
    "Export": "50"
  },
  {
    "Date": "2019-03",
    "Import": "800",
    "Export": "200"
  },
  {
    "Date": "2019-04",
    "Import": "100",
    "Export": "600"
  }
]

Это мой скрипт php:

$url = dirname(__DIR__  ) . '/admin/json/all.json';
$json = file_get_contents($url);
$array_origin = json_decode($json, TRUE);

$stack=array(); 
foreach ($array_origin as $index => $array_part) {
  $stack[$array_part['Date']] =array_key_exists($array_part['Date'],$stack)?$stack[$array_part['Date']]+$array_part['Import']:$array_part['Import'];
}

echo '<pre>' . var_export($stack, true) . '</pre>';

Однако с помощью этого скрипта я могу только суммировать «импорт», но я хочу также суммировать «экспорт».

По этой причине я ищу вашей помощи. Я ценю любую помощь от вас, ребята.

Заранее спасибо. Ваше здоровье

Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
1
0
54
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Вам нужно добавить ключи Import и Export в массив результатов. Я попытался сократить его и использовал isset:

foreach ($array_origin as $v) {
    $stack[$v['Date']]['Import'] = isset($v['Date']) ? $stack[$v['Date']]['Import'] + $v['Import'] : $v['Import'];
    $stack[$v['Date']]['Export'] = isset($v['Date']) ? $stack[$v['Date']]['Export'] + $v['Export'] : $v['Export'];
}

Префект. Спасибо :)

ficolixado 08.04.2019 19:21

Извините, позвольте спросить, хочу ли я сделать средний "Импорт"?

ficolixado 08.04.2019 19:24
array_column($stack, 'Import') затем array_sum / count
AbraCadaver 08.04.2019 19:30

Спасибо за помощь, я очень ценю :)

ficolixado 08.04.2019 19:33

Другие вопросы по теме