Я пытаюсь заменить некоторое значение в многомерном массиве другим массивом с тем же ключом а получается заменить все значения
Вот мой пример массива
[
{
"book_id": 45,
"language_code": "RUWT-EN",
"book_name": Study,
"country": "Singapore",
"created_by": 12,
"created_date": "2019-04-09 09:19:24",
"update_by": 12,
"update_date": "2019-06-25 03:57:52",
"status": "1",
},
{
"book_id": 46,
"language_code": "RUWT-EN",
"book_name": Sleep,
"country": "Indonesia",
"created_by": 12,
"created_date": "2019-04-09 09:19:24",
"update_by": 12,
"update_date": "2019-06-25 03:57:52",
"status": "1",
},
{
"book_id": 47,
"language_code": "RUWT-EN",
"book_name": Teaching,
"country": "China",
"created_by": 12,
"created_date": "2019-04-09 09:19:24",
"update_by": 12,
"update_date": "2019-06-25 03:57:52",
"status": "1",
},
]
и это мой второй массив
[
{
"book_id": 45,
"language_code": "RUWT-CH",
"book_name": Study in CH,
"country": "Korea",
"status": "2",
},
{
"book_id": 46,
"language_code": "RUWT-CH",
"book_name": Sleep in CH,
"country": "US",
"status": "2",
},
{
"book_id": 47,
"language_code": "RUWT-CH",
"book_name": Teaching in CH,
"country": "England",
"status": "2",
},
]
Я пробовал использовать коллекцию карт laravel и значения foreach по одному, а затем заменять значение с тем же ключом, но это было слишком долго. я хочу Самый простой способ
$result = $collect_real->map(function($item) use($lang){
return $item['book_name'] = $lang->where('book_id', $item['book_id'])->values();
});
я хочу такой результат
[
{
"book_id": 45,
"language_code": "RUWT-CH",
"book_name": Study in CH,
"country": "Korea",
"created_by": 12,
"created_date": "2019-04-09 09:19:24",
"update_by": 12,
"update_date": "2019-06-25 03:57:52",
"status": "2",
},
{
"book_id": 46,
"language_code": "RUWT-CH",
"book_name": Sleep in CH,
"country": "US",
"created_by": 12,
"created_date": "2019-04-09 09:19:24",
"update_by": 12,
"update_date": "2019-06-25 03:57:52",
"status": "2",
},
{
"book_id": 47,
"language_code": "RUWT-CH",
"book_name": Teaching in CH,
"country": "England",
"created_by": 12,
"created_date": "2019-04-09 09:19:24",
"update_by": 12,
"update_date": "2019-06-25 03:57:52",
"status": "2",
},
]
У вас есть все записи с одинаковым идентификатором книги.
@GiacomoMasseroniChiaro это не работает, я хочу заменить некоторое значение в 1-м массиве на 2-й массив
@DrakulaPredatorم отредактировал, спасибо
Каково ваше фактическое поведение. Что происходит не так?






Функция array_replace_recursive решает вашу проблему одной строкой кода:
From the docs:
array_replace_recursive() replaces the values of array1 with the same values from all the following arrays. If a key from the first array exists in the second array, its value will be replaced by the value from the second array. If the key exists in the second array, and not the first, it will be created in the first array. If a key only exists in the first array, it will be left as is. If several arrays are passed for replacement, they will be processed in order, the later array overwriting the previous values.
array_replace_recursive() is recursive: it will recurse into arrays and apply the same process to the inner value.
Пример:
$updatedBooks = array_replace_recursive($wrongBooksArray, $correctBooksArray);
Я пробовал, и это работает отлично. Большое спасибо
Я не понимаю, в чем твоя проблема. Ваш код работает или нет?