Мне нужно объединить данные двух двухмерных массивов, связанных общим значением столбца. Если общее значение не найдено, массив результатов должен применить нулевое значение по умолчанию для нового столбца.
$mahasiswa = [
['npm' => 1123123123, 'nama' => 'LINDA'],
['npm' => 121323131, 'nama' => 'SETIADI'],
['npm' => 12312312, 'nama' => 'WIWIN'],
['npm' => 12345678910, 'nama' => 'ABDUL IMAN'],
['npm' => 12355141, 'nama' => 'KOKOM'],
['npm' => '123U4148U90', 'nama' => 'JIHAN'],
['npm' => 978687999, 'nama' => 'KURNIA']
];
$piutang = [
['total' => 14600000, 'nama' => 'KOKOM', 'npm' => 12355141],
['total' => 8000000, 'nama' => 'KURNIA', 'npm' => 978687999]
];
Мой текущий код:
$i = 0;
$rekappiutang = array();
foreach ($mahasiswa as $row) {
foreach ($piutang as $key=>$val) {
if ($val['npm'] == $row['npm']) {
$rekappiutang[$i]['npm'] = $row['npm'];
$rekappiutang[$i]['nama'] = $row['nama'];
$rekappiutang[$i]['totalpiutang'] = $val['total'];
} else {
$rekappiutang[$i]['npm'] = $row['npm'];
$rekappiutang[$i]['nama'] = $row['nama'];
$rekappiutang[$i]['totalpiutang'] = 0;
}
}
$i++;
}
К сожалению, не все связанные итоги корректно применяются к новому столбцу.
Мой желаемый результат:
[
['npm' => 1123123123, 'nama' => 'LINDA', 'total' => 0],
['npm' => 121323131, 'nama' => 'SETIADI', 'total' => 0],
['npm' => 12312312, 'nama' => 'WIWIN', 'total' => 0],
['npm' => 12345678910, 'nama' => 'ABDUL IMAN', 'total' => 0],
['npm' => 12355141, 'nama' => 'KOKOM', 'total' => 0],
['npm' => '123U4148U90', 'nama' => 'JIHAN', 'total' => 0],
['npm' => 978687999, 'nama' => 'KURNIA', 'total' => 0]
]
Подробнее здесь: https://stackoverflow.com/questions/203 ... umn-otherw
Сопоставьте значения из 2D-массива с другим 2D-массивом, связанным общим столбцом, в противном случае используйте значен ⇐ Php
Кемеровские программисты php общаются здесь
1733556026
Anonymous
Мне нужно объединить данные двух двухмерных массивов, связанных общим значением столбца. Если общее значение не найдено, массив результатов должен применить нулевое значение по умолчанию для нового столбца.
$mahasiswa = [
['npm' => 1123123123, 'nama' => 'LINDA'],
['npm' => 121323131, 'nama' => 'SETIADI'],
['npm' => 12312312, 'nama' => 'WIWIN'],
['npm' => 12345678910, 'nama' => 'ABDUL IMAN'],
['npm' => 12355141, 'nama' => 'KOKOM'],
['npm' => '123U4148U90', 'nama' => 'JIHAN'],
['npm' => 978687999, 'nama' => 'KURNIA']
];
$piutang = [
['total' => 14600000, 'nama' => 'KOKOM', 'npm' => 12355141],
['total' => 8000000, 'nama' => 'KURNIA', 'npm' => 978687999]
];
Мой текущий код:
$i = 0;
$rekappiutang = array();
foreach ($mahasiswa as $row) {
foreach ($piutang as $key=>$val) {
if ($val['npm'] == $row['npm']) {
$rekappiutang[$i]['npm'] = $row['npm'];
$rekappiutang[$i]['nama'] = $row['nama'];
$rekappiutang[$i]['totalpiutang'] = $val['total'];
} else {
$rekappiutang[$i]['npm'] = $row['npm'];
$rekappiutang[$i]['nama'] = $row['nama'];
$rekappiutang[$i]['totalpiutang'] = 0;
}
}
$i++;
}
К сожалению, не все связанные итоги корректно применяются к новому столбцу.
Мой желаемый результат:
[
['npm' => 1123123123, 'nama' => 'LINDA', 'total' => 0],
['npm' => 121323131, 'nama' => 'SETIADI', 'total' => 0],
['npm' => 12312312, 'nama' => 'WIWIN', 'total' => 0],
['npm' => 12345678910, 'nama' => 'ABDUL IMAN', 'total' => 0],
['npm' => 12355141, 'nama' => 'KOKOM', 'total' => 0],
['npm' => '123U4148U90', 'nama' => 'JIHAN', 'total' => 0],
['npm' => 978687999, 'nama' => 'KURNIA', 'total' => 0]
]
Подробнее здесь: [url]https://stackoverflow.com/questions/20315150/map-values-from-a-2d-array-to-another-2d-array-related-by-a-shared-column-otherw[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия