3

我正在尝试使用 CodeIgniter 2.x 从头开始​​创建一个网上商店。一家商店有自己的制造商的产品,如Glock、Colt、Kalashnikov、Boker、CZ、Kizlyar、GroundZero等......

我需要为与和混合的每种产品创建唯一的SKU (库存单位)名称。这样做是没有问题的,即:带有 的产品的SKU 变为:groundzero-0013product.idproduct.manufacturerid=13manufacturer=GroundZeroname=Striker II

我需要生成缩写,以便 SKU 变成这样:grzr-0013gnzr-0013

有什么解决办法吗?

4

1 回答 1

4

我根据您提到的规格编写了以下 SKU 生成器,您可以更改$l以使其更加独特(在某种程度上):

echo SKU_gen('ZeroGround', 13, 2).'<br>'; // zrgr-0013
echo SKU_gen('ZeroGround', 13, 3).'<br>'; // zrgrn-0013
echo SKU_gen('Glock', 14, 3).'<br>'; // glc-0014
echo SKU_gen('CZ', 15, 3).'<br>'; // cz-0015
echo SKU_gen('Kizlyar', 20).'<br>'; // kz-0020

function SKU_gen($string, $id = null, $l = 2){
    $results = ''; // empty string
    $vowels = array('a', 'e', 'i', 'o', 'u', 'y'); // vowels
    preg_match_all('/[A-Z][a-z]*/', ucfirst($string), $m); // Match every word that begins with a capital letter, added ucfirst() in case there is no uppercase letter
    foreach($m[0] as $substring){
        $substring = str_replace($vowels, '', strtolower($substring)); // String to lower case and remove all vowels
        $results .= preg_replace('/([a-z]{'.$l.'})(.*)/', '$1', $substring); // Extract the first N letters.
    }
    $results .= '-'. str_pad($id, 4, 0, STR_PAD_LEFT); // Add the ID
    return $results;
}
于 2013-04-05T10:10:58.077 回答