我正在尝试使用CodeIgniter 2.x从头开始创建一个网店。一家商店有自己的制造商的产品,如格洛克,柯尔特,卡拉什尼科夫,博克,CZ, Kizlyar, GroundZero等…
我需要为每个混合了product.id
和product.manufacturer
的产品创建唯一的SKU(Stock Keeping Unit)名称。这样做没有问题,即:SKU对于具有id=13
, manufacturer=GroundZero
和name=Striker II
的产品变为: ground0 -0013
我需要生成缩写,使SKU变成这样:grzr-0013或gnzr-0013
解决方案吗?
我根据您提到的规格编写了以下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;
}