Сгруппируйте 2d коллекцию Laravel по двум столбцам и суммируйте третий столбец в каждой группе

У меня есть эта коллекция:

$stocks = collect(
    [
        ['sku' => '123', 'batch' => '123', 'qty_total' => 1],
        ['sku' => '1233', 'batch' => '123', 'qty_total' => 2],
        ['sku' => '123', 'batch' => '123', 'qty_total' => 3],
        ['sku' => '5', 'batch' => '123', 'qty_total' => 4],
    ]
);

И мне нужно получить коллекцию выходных данных следующим образом:

[
        ['sku' => '123', 'batch' => '123', 'qty_total' => 4],
        ['sku' => '1233', 'batch' => '123', 'qty_total' => 2],
        ['sku' => '5', 'batch' => '123', 'qty_total' => 4],
    ]

Я группирую коллекцию с

$coll = $coll
    ->groupBy(['sku','batch'], true)

Но я не понимаю, как мне суммировать дальше.

Отвечает ли это на ваш вопрос ? stackoverflow.com/questions/37675819/…

shirshak007 11.06.2024 10:38

да, но я хочу сделать это с помощью методов сбора laravel

Maksim Borodov 11.06.2024 10:46

Отвечает ли это на ваш вопрос? Коллекция Laravel с группировкой, подсчетом и суммированием

N69S 11.06.2024 11:21
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать 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 и хотите разрабатывать...
0
3
88
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Вы можете сделать это следующим образом:

  $stocks = collect(
   [
      ['sku' => '123', 'batch' => '123', 'qty_total' => 1],
      ['sku' => '1233', 'batch' => '123', 'qty_total' => 2],
      ['sku' => '123', 'batch' => '123', 'qty_total' => 3],
      ['sku' => '5', 'batch' => '123', 'qty_total' => 4],
   ]
  );

return $stocks->groupBy(['sku','batch'], true)->map(function($items){
  $firstItem = $items->values()->first();

  return collect($firstItem->first())->merge([
    'qty_total' => $firstItem->sum('qty_total')
  ]);
})->values();

Однако есть одна ошибка: если у меня все еще есть ключ, код Manufacturing_date будет работать некорректно.

Maksim Borodov 11.06.2024 14:09

Извините за это, покажите мне новый ввод, пожалуйста, и в чем проблема, я постараюсь вам помочь.

Mohammad si abbou 11.06.2024 16:24

Мне нужно сделать это и сгруппировать для динамического массива groupBy, для группировки может быть более двух элементов.

Maksim Borodov 13.06.2024 06:56

Вот это с Manufacturing_date 3v4l.org/bVqEN6

Mohammad si abbou 13.06.2024 10:28
Ответ принят как подходящий

Передача двухэлементного массива в метод groupBy() только увеличивает объем работы/обработки, потому что генерирует излишне глубокую структуру. Обратите внимание, как фрагмент Мохаммеда должен переиндексироваться (values()), затем вызывать first(), затем снова first(), чтобы перейти на желаемый уровень.

Вместо этого передайте groupBy() функцию обратного вызова, чтобы сформировать «ключ составной строки» и сохранить сгруппированные данные поверхностными.

Код: (Демо-версия PHPize)

var_export(
    $stocks
    ->groupBy(fn($row) => $row['sku'] . '_' . $row['batch'])
    ->map(fn($set) => array_merge($set->first(), ['qty_total' => $set->sum('qty_total')]))
    ->values()
    ->toArray()
);

Выход:

array (
  0 => 
  array (
    'sku' => '123',
    'batch' => '123',
    'qty_total' => 4,
  ),
  1 => 
  array (
    'sku' => '1233',
    'batch' => '123',
    'qty_total' => 2,
  ),
  2 => 
  array (
    'sku' => '5',
    'batch' => '123',
    'qty_total' => 4,
  ),
)

Тематически связанный контент:

Ага! Это решение работает для группы с более чем двумя ключами!

Maksim Borodov 13.06.2024 07:00

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