首页 > 解决方案 > 如何从 Explode 中获取数据并检查是否相同的数据

问题描述

我有案例将现有数据等同起来

我有 2 个格式像这样的数据

$data1 = "144|aku|1!!!122|dia|2";  data description "id|name|amount"

$data2 = "144|aku|1!!!211|dia|1";

2个数组有相同的数据,如何使数量部分相同的数据可以相加,不相等的数据会被插入到数组中

如何让2个数组变成这样

$data_result  = "144|aku|2!!!122|dia|2!!!211|dia|1";

这是我的完整脚本

$data1 = "144|aku|1!!!122|dia|2";

$data2 = "144|aku|1!!!211|dia|1";


    $simpan_array = array();
    $array_status = array();
               // Pecah Array dari user dulu

               $array_code_user =  explode('!!!', $data1 );
               $jumlah_item_user = count($array_code_user) - 1;
               $x = 0;

               // Pecah Array dari lokal
               $array_cart_local   = explode('!!!',$data2 );
               $jumlah_cart_local  = count($array_cart_local) - 1;
               $j = 0;

                while( $x <= $jumlah_item_user ) {
                    $ambil_datacart_user = explode( '|', $array_code_user[$x] );

                        $idproduk_user   = $ambil_datacart_user[0];
                        $namaprod_user   = $ambil_datacart_user[1];
                        $jumprod_user    = $ambil_datacart_user[2];

                        $simpan_array_0 = $idproduk_user.'|'.$namaprod_user.'|'.$jumprod_user;
                        while( $j <= $jumlah_cart_local ) {
                            $ambil_datacart_lokal = explode( '|', $array_cart_local[$j] );

                                $idprod_lokal     = $ambil_datacart_lokal[0];
                                $namaprod_lokal   = $ambil_datacart_lokal[1];
                                $jumprod_lokal    = $ambil_datacart_lokal[2];

                                $simpan_array_1 = $idprod_lokal.'|'.$namaprod_lokal.'|'.$jumprod_lokal;
                                //Disamakan

                                    if( $idproduk_user == $idprod_lokal ) {
                                        $jumtotal = $jumprod_user + $jumprod_lokal;

                                        $simpan_array[] = $idprod_lokal.'|'.$namaprod_lokal.'|'.$jumtotal;
                                        $array_status[] = 1;
                                    } else {

                                        $simpan_array[] = $simpan_array_1;

                                        $array_status[] = 0;
                                    }

                          $j++;
                        }

                  $x++;      

                }

              $jumlah = array_sum($array_status);
              $array_jadi = join("!!!",$simpan_array);
              //$datakembali = $array_jadi;
              if ( $jumlah == 0 ) {
                        $datakembali = $simpan_array_1.'!!!'.$array_jadi;
               } else {
                        $datakembali = $array_jadi;
               }
               echo $datakembali;
               ?>

标签: phpexplode

解决方案


您可以执行以下操作:

$array1 = "144|aku|1!!!122|dia|2";
$array2 = "144|aku|1!!!211|dia|1";

//Convert the string into array by explode
$array1 = explode( '!!!', $array1 );
$array2 = explode( '!!!', $array2 );

//Merge the 2 arrays
$merged = array_merge($array1,$array2);

//Group the array using foreach
//Loop thru the array and group using the id as key
$grouped = array();
foreach( $merged as $key => $val ) {
    $val = explode( '|', $val );                                     //Convert the string into array
    if ( !isset( $grouped[ $val[0] ] ) ) $grouped[ $val[0] ] = $val; //If key does not exist, initialise the data
    else $grouped[ $val[0] ][2] += $val[2];                          //If key already exist, just add the third value
}

//Format the grouped array into string
foreach( $grouped as $key => $val ) {
    $grouped[ $key ] = implode( '|', $val );
}
$result = implode( '!!!', $grouped );

echo $result;

这将导致:

144|aku|2!!!122|dia|2!!!211|dia|1

推荐阅读