Мне нужно объединить данные строк моего двухмерного массива, где строки имеют одно и то же значение messageID.
$myarray = [
[
'messageId' => '5ACE9D8841',
'sender' => 'john@doe.com'
],
[
'messageId' => '7EE67D8170',
'sender' => 'dan@doe.com'
],
[
'messageId' => '8095FD8836',
'sender' => 'cat@doe.com'
],
[
'messageId' => '7EE67D8170',
'dest' => 'mitch@doe.com',
'status' => 'sent',
'date' => '2021-02-01 11:06:55'
]
];
Из примера данных строки [1] и [3] объединяются в [1], поскольку они имеют один и тот же [messageId]. Ожидаемый результат:
Array
(
[0] => Array
(
[messageId] => 5ACE9D8841
[sender] => john@doe.com
)
[1] => Array
(
[messageId] => 7EE67D8170
[dest] => mitch@doe.com
[status] => sent
[date] => 2021-02-01 11:06:55
[sender] => dan@doe.com
)
[2] => Array
(
[messageId] => 8095FD8836
[sender] => cat@doe.com
)
)
Я не возражаю против индекса ключа или порядка.
EDIT: я пробовал array_merge, array_merge_recursive и многие другие. Наилучший результат был получен при использовании
$result_arr = array();
foreach ($myarray as $sub_arr) {
$result_arr = array_merge($result_arr, $sub_arr);
$result_arr = array_unique($result_arr);
}
Он работает, но возвращает только последнюю итерацию:
Array (
[messageId] => 7EE67D8170
[dest] => mitch@doe.com
[status] => sent
[date] => 2021-02-01 11:06:55
[sender] => dan@doe.com
)
Подробнее здесь: https://stackoverflow.com/questions/660 ... lumn-value
Объединение данных ассоциативной строки в двумерный массив на основе значения столбца ⇐ Php
Кемеровские программисты php общаются здесь
1729764015
Anonymous
Мне нужно объединить данные строк моего двухмерного массива, где строки имеют одно и то же значение messageID.
$myarray = [
[
'messageId' => '5ACE9D8841',
'sender' => 'john@doe.com'
],
[
'messageId' => '7EE67D8170',
'sender' => 'dan@doe.com'
],
[
'messageId' => '8095FD8836',
'sender' => 'cat@doe.com'
],
[
'messageId' => '7EE67D8170',
'dest' => 'mitch@doe.com',
'status' => 'sent',
'date' => '2021-02-01 11:06:55'
]
];
Из примера данных строки [1] и [3] объединяются в [1], поскольку они имеют один и тот же [messageId]. Ожидаемый результат:
Array
(
[0] => Array
(
[messageId] => 5ACE9D8841
[sender] => john@doe.com
)
[1] => Array
(
[messageId] => 7EE67D8170
[dest] => mitch@doe.com
[status] => sent
[date] => 2021-02-01 11:06:55
[sender] => dan@doe.com
)
[2] => Array
(
[messageId] => 8095FD8836
[sender] => cat@doe.com
)
)
Я не возражаю против индекса ключа или порядка.
EDIT: я пробовал array_merge, array_merge_recursive и многие другие. Наилучший результат был получен при использовании
$result_arr = array();
foreach ($myarray as $sub_arr) {
$result_arr = array_merge($result_arr, $sub_arr);
$result_arr = array_unique($result_arr);
}
Он работает, но возвращает только последнюю итерацию:
Array (
[messageId] => 7EE67D8170
[dest] => mitch@doe.com
[status] => sent
[date] => 2021-02-01 11:06:55
[sender] => dan@doe.com
)
Подробнее здесь: [url]https://stackoverflow.com/questions/66066156/merge-associative-row-data-in-a-2d-array-based-on-a-column-value[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия