我有一些。ini文件,我不能改变。它看起来像:
01code6=77
01name6=G 650 Xcountry/Xmoto/Xchallenge (K15) [V] [77]
01type6=Bike
01code7=E3
01name7=i3 od 07/13 (I01) [V] [S] [3D] [IRE] [E3]
01type7=Car
01code8=E8
01name8=i8 kupé od 03/14 (I12) [V] [3D] [E8]
01type8=Car
01code9=80
01name9=K 100 - K 1200 RS / K1 od 04/84 [V] [80]
01type9=Bike
解析它的代码如下:
public function pasrseString($path)
{
$ini = parse_ini_file($path, false, INI_SCANNER_RAW);
foreach(array_chunk($ini, 3, true) as $data)
{
// $data is an array of just the 3 that are related
$mcode = substr(array_keys($data)[0], 0, 2);
$nameLine = array_values($data)[1];
$typeLine = array_values($data)[2];
$vehicle = array_values($data)[0];
echo $vehicle;
echo "<br>";
echo $typeLine;
echo "<br>";
echo $nameLine;
echo "<br>";
echo $mcode;
}
}
如你所见,在。ini文件中,每辆车都有3行,
- 第一行代码
- 第二行名称
- 第三行,载具_type
我的脚本可以得到正确的值,尽管这个事实,我的循环失败,因为有错误的值在变量。例如,如果我在整个文件上运行这个循环Echo $vehicle对一些车辆返回车辆数据,对另一些车辆返回车辆类型,对另一些返回McOde,尽管在文件中总是有这样的顺序。
我真的很困惑,在这个循环中我做错了什么,有人能帮我找到解决方案吗?
注。如果我在foreach(array_chunk($ini, 3, true) as $data)
编辑:我发现代码中有一些空白的数据,例如
01code0=
01name0=
因此,带有空值的示例代码看起来像:
00code46=65
00name46=TT kupé od 07/14 (FV) [V] [S] [3D] [65]
00type46=Car
00code47=45
00name47=TT od 08/06 (8J) [V] [S] [3D] [IRE] [45]
00type47=Car
01code0=
01name0=
01code1=M2
01name1=C 600 Sport/C 650 GT od 01/12 (K18/0131) (K19/0133) [V] [M2]
01type1=Bike
01code2=70
01name2=F 650 GS / F 800 GS od mod. ´08 [V] [70]
01type2=Bike
01code3=84
在整个文档中有5个空白值所以真的不多
稍作修饰:
$vehicles = array_map(function($vs){
return array_combine(array('code','name','type'),$vs);
}, array_chunk(parse_ini_string($x,false,INI_SCANNER_RAW),3));
parse ini, chunkify, map over chunks将位置转换为名称
完整代码:
$x = <<<EOD
01code6=77
01name6=G 650 Xcountry/Xmoto/Xchallenge (K15) [V] [77]
01type6=Bike
01code7=E3
01name7=i3 od 07/13 (I01) [V] [S] [3D] [IRE] [E3]
01type7=Car
01code8=E8
01name8=i8 kupé od 03/14 (I12) [V] [3D] [E8]
01type8=Car
01code9=80
01name9=K 100 - K 1200 RS / K1 od 04/84 [V] [80]
01type9=Bike
EOD;
$vehicles = array_map(function($vs){
return array_combine(array('code','name','type'),$vs);
}, array_chunk(parse_ini_string($x,false,INI_SCANNER_RAW),3));
var_dump($vehicles); // over which you can iterate to produce the output
/*
array(4) {
[0]=>
array(3) {
["code"]=>
string(2) "77"
["name"]=>
string(46) "G 650 Xcountry/Xmoto/Xchallenge (K15) [V] [77]"
["type"]=>
string(4) "Bike"
}
[1]=>
array(3) {
["code"]=>
string(2) "E3"
["name"]=>
string(41) "i3 od 07/13 (I01) [V] [S] [3D] [IRE] [E3]"
["type"]=>
string(3) "Car"
}
[2]=>
array(3) {
["code"]=>
string(2) "E8"
["name"]=>
string(37) "i8 kupé od 03/14 (I12) [V] [3D] [E8]"
["type"]=>
string(3) "Car"
}
[3]=>
array(3) {
["code"]=>
string(2) "80"
["name"]=>
string(40) "K 100 - K 1200 RS / K1 od 04/84 [V] [80]"
["type"]=>
string(4) "Bike"
}
}
*/