我有一个已转换为多个数组的csv。该阵列的一个元素包含鞋码作为字符串。这些大小可以是2到16之间的任何数字组。
我已经爆炸了弦以将每个尺寸放置在它自己的元素中,因此我可以将每个尺码之间的管道特征内爆。在我破坏阵列之前,我想将鞋子尺寸从一个数字改为英国,美国和欧盟尺寸,例如2成为UK2 / US6 / EU36 3成为UK3 / US7 / EU37等......
我已经看过preg repalce preg match array splice但我遇到的问题是数组中的第一个元素并不总是相同的大小。它可以从任何鞋码开始,具体取决于库存。也可能错过订单中的尺寸。
我已经看过这个解决方案,但不确定这是否是最佳方式Replace elements in an array depending on their value
$exp = explode(" ", $data[12]);
print_r($exp);
//change form size into UK/US/EU sizes ?
//add pipe character bewtween size and return to string
$imp = implode("|", $exp);
$model = str_replace("Model: ", "", $data[13]);
$brand = str_replace("Manufactured by: ", "", $data[14]);
// This is where you build your array output
$outputData = array($data[5], $data[6], $data[7], $data[15], $data[16], $data[21]= $model, $data[22]= $imp, $data[23]= $brand);
这是我想要做的事情
爆炸后的原始代码
Array
(
[0] => 2
[1] => 3
[2] => 4
[3] => 5
[4] => 6
[5] => 7
[6] => 8
[7] => 9
)
更改为
Array
(
[0] => UK2/US5/EU35
[1] => UK3/US6/EU36
[2] => UK4/US7/EU37
[3] => UK5/US8/EU38
[4] => UK6/US9/EUR39
[5] => UK7/US10/EU40
[6] => UK8/US11/EU41
[7] => UK9/US12/EUR42
)
然后,我可以崩溃。
答案 0 :(得分:2)
这应该适合你:
只需使用array_map()
浏览每个数组元素,然后根据需要进行更改:
<?php
$exp = array_map(function($v){
return "UK" . $v . "/US" . ($v + 3) . "/EU" . ($v + 33);
}, $exp);
print_r($exp);
?>
答案 1 :(得分:1)
这可能是这么简单吗?
foreach($exp as &$v) {
$v = 'UK'.$v.'/US'.($v+3).'/EU'.($v+33);
}