php foreach组的结果由3组字符组成

时间:2017-11-21 12:59:15

标签: php arrays foreach

我正在尝试根据前3组字符对一些foreach结果进行分组。

例如,我目前正在列出产品的sku代码,它们看起来像这样:

REF-MUSBOM-0500-ORA
REF-PROCOF-0001-LAT
REF-WHEREF-0001-TRO
REF-WHEREF-0001-ORA
REF-SHAKER-0700-C/B
REF-CREMON-0100-N/A
REF-GLUSUL-0090-N/A
REF-CRECAP-0090-N/A
REF-ALBFER-0120-N/A
REF-TSHCOT-LARG-BLK
REF-TSHCOT-MEDI-BLK
REF-ALBMAG-0090-N/A
REF-GYMJUG-2200-N/A
REF-OMEGA3-0090-N/A
REF-NEXGEN-0060-N/A
REF-VITAD3-0100-N/A
REF-SSSHAK-0739-N/A
REF-GINKGO-0090-N/A
REF-DIGEZY-0090-N/A
REF-VEST00-MEDI-N/A
REF-VEST00-LARG-N/A
REF-CREMON-0250-N/A
REF-MSM----0250-N/A
REF-GRNTEA-0100-N/A
REF-COLOST-0100-N/A
REF-GLUCHO-0090-N/A
REF-ZINCMA-0100-N/A
REF-BETALA-0250-N/A
REF-DRIBOS-0250-N/A
REF-HMB000-0090-N/A
REF-ALACID-0090-N/A
REF-CLA000-0090-N/A
REF-ACETYL-0090-N/A
REF-NXGPRO-0090-N/A
REF-LGLUTA-0250-N/A
REF-BCAA20-0200-N/A
REF-FLAPJA-0012-ACR
REF-FLAPJA-0012-MAP
REF-LCARNI-0100-N/A
REF-CORDYC-0090-N/A
REF-CREMON-0500-N/A
REF-BCAAEN-0330-APP
REF-PREWKT-0300-FPU
REF-TESFUS-0090-N/A
REF-AMIIFUS-0300-GAP
REF-AMIIFUS-0300-WME
REF-BCAINT-0400-FPU
REF-KRILLO-0090-N/A
REF-AMIIFUS-0300-PLE
REF-AMIIFUS-0300-FPU
REF-BCAINT-0400-WME
REF-ENZQ10-0090-N/A
REF-THERMO-0100-N/A
REF-LGLUTA-0500-N/A
REF-RBAR00-0012-DCB
REF-RBAR00-0012-PBC
REF-RBAR00-0012-WCR
REF-IMHEAV-2200-CHO
REF-PROCOF-0012-N/A
REF-DIEPRO-0900-STR
REF-DIEPRO-0900-BOF
REF-DIEPRO-0900-CHO
REF-INWPRO-0900-VAN
REF-INWPRO-0900-BOF
REF-INWPRO-0900-BCS
REF-INWPRO-0900-CHO
REF-INWPRO-0900-CMI
REF-INWPRO-0900-RAS
REF-INWPRO-0900-STR
REF-INWPRO-0900-CIN
REF-INWPRO-0900-CPB
REF-EGGPRO-0900-CHO
REF-EGGPRO-0900-VAN
REF-MICCAS-0909-CHO
REF-MICCAS-0909-CMI
REF-MICCAS-0909-VAN
REF-MICCAS-0909-STR
REF-BCAA50-0500-N/A
REF-MICWHE-0909-STR
REF-MICWHE-0909-VAN
REF-MICWHE-0909-CHIO
REF-MICWHE-0909-BAN
REF-1STOXT-2030-STR
REF-1STOXT-2030-VAN
REF-1STOXT-2030-CHO
REF-MUSBOM-0600-BCH
REF-MUSBOM-0600-FPU
REF-MUSBCF-0600-BCH
REF-MUSBCF-0600-FPU
REF-VEGANP-2100-STR
REF-VEGANP-2100-CHO
REF-INMPRO-2270-CPB
REF-DIETMR-2400-CPB
REF-INMPRO-2270-SCR
REF-INMPRO-2270-VIC
REF-MATRIX-1800-FRU
REF-INMPRO-2270-BOF
REF-MATRIX-1800-CHO
REF-INMPRO-2270-CHO
REF-ONESTO-2100-CHO

在上面的列表中有2个skus:

REF-WHEREF-0001-TRO
REF-WHEREF-0001-ORA

-分割的前3组字符是相同的。将所有结果分组的最佳方法是什么,这给我一个类似的数组:

Array
(
[REF-WHEREF-0001] => Array
    (
        [0] => REF-WHEREF-0001-TRO
        [1] => REF-WHEREF-0001-ORA

    )
)

3 个答案:

答案 0 :(得分:1)

前3个组(不包括多个-)总是13个字符吗?然后做这样的事情:

<?php
$arr = ["REF-MUSBOM-0500-ORA",
    "REF-PROCOF-0001-LAT",
    "REF-WHEREF-0001-TRO",
    "REF-WHEREF-0001-PPL"];

$resultArr = [];
foreach ($arr as $sku) {
    $resultArr[substr($sku, 0, 15)][] = $sku;
}

var_dump($resultArr);

如果该长度有所不同,您可能希望使用正则表达式或第三个strpos()的{​​{1}}。

我必须说,我认为你可以自己想出这个,因为你已经在思考正确的方向,即-

编辑:因为我发现其他解决方案更优雅,我决定compare efficiency。这个解决方案比其他解决方案快得多。

答案 1 :(得分:1)

我总是使用组所需的索引创建一个新数组,试试这个:

    $arr=array('REF-MUSBOM-0500-ORA',
'REF-PROCOF-0001-LAT',
'REF-WHEREF-0001-TRO');
$newarr=array();
foreach($arr as $a){
    $b=explode('-',$a);
    array_pop($b);
    $b=implode("-", $b);
    $newarr[$b][]=$a;
}
echo '<pre>',print_r($newarr),'</pre>';

答案 2 :(得分:0)

您需要选择一个基础使用explode,implode和str_replace的组。

这个解决方案做了什么。

  1. 循环浏览项目数组
  2. 爆炸以获取爆炸字符串的最后一项索引(假设它) 最终将是动态的
  3. implode&amp;再次str_replace找出组名字符串
  4. 最后一个strpos&amp; in_array有样本响应
  5. <强>解决方案

    $array = array(
        'REF-MUSBOM-0500-ORA',
        'REF-PROCOF-0001-LAT',
        'REF-WHEREF-0001-TRO',
        'REF-WHEREF-0001-ORA',
        'REF-SHAKER-0700-C/B',
        'REF-CREMON-0100-N/A',
        'REF-GLUSUL-0090-N/A',
        'REF-CRECAP-0090-N/A',
        'REF-ALBFER-0120-N/A',
    );
    
    $new_array = array();
    foreach ($array as $key => $val) {
        $group_arr = explode('-', $val);
        $end = end($group_arr);
        $combined_group = implode('-', $group_arr);
        $group = str_replace('-' . $end, '', $combined_group);
    
        if (strpos($val, $group) !== false && !in_array($group, $new_array)) {
            $new_array[$group][] = $val;
        }
    }
    echo '<pre>';print_r($new_array);echo '</pre>';
    

    请参阅 Sandbox

    上的演示