简体   繁体   中英

Merge or update multidimensional associative array using php

I have two arrays.

$all_labels = [
    'data'=> [
        ['label'=> NULL],
        ['label'=> "C1.SNM"],
        ['label'=> "C1.SSM"],
        ['label'=> "C1.TAM"],
        ['label'=> "C1.TIM"],
        ['label'=> "C1.TNM"],
        ['label'=> "C1.TOM"]
    ]
];

$non_complianceData3 = [
    'data'=> [
        ['label'=> "C1.TAM", 'value'=> "1674"],
        ['label'=> "C1.TOM", 'value'=> "574"]
    ]
];

I need the first array to act as the base, ie this returns all the labels available from the db. I then need to update the base by using the $non_complianceData3 array data values with the matching labels, in this case the base "C1.TAM" needs to be updated with 'value'=> "1674" , and the "C1.TOM" with 'value'=> "574" .

How do I go about doing this?

If the labels in $all_labels are distinct, it can be done this way:

// reindex $all_labels['data'] by label
$all_labels['data'] = array_column($all_labels['data'], null, 'label');

// assign the values from $non_complianceData3['data'] to the new keys
foreach ($non_complianceData3['data'] as $item) {
    $all_labels['data'][$item['label']] = $item;
}

If the labels in $all_labels are not distinct, it can be done like this:

// loop over the items in $non_complianceData3['data']
foreach ($non_complianceData3['data'] as $item) {

    // find all of the matching labels in $all_labels['data'] and replace
    // them with the corresponding $non_complianceData3['data'] items
    foreach ($all_labels['data'] as $key => $value) {
        if ($item['label'] == $value['label']) {
            $all_labels['data'][$key] = $item;
        }
    }
}

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM