如何使用 while 循环以编程方式创建多维数组

我正在尝试使用 PHP 读取 CSV 文件并根据特定行的匹配构建数组。CSV 文件内容如下所示:


id, name, qty, price

1,Jeff,2,59,

2,Tom,3,36,

3,Lenny,2,25,

4,Tom,5,69,

5,Jeff,3,19,

6,Tom,2,75,

我使用“while”循环来读取 CSV 文件:


while (($row = fgetcsv($h, 10000, ",")) !== FALSE) {

这个想法是:如果在阅读 CSV 文件时,发现与 $row[1] 匹配,如下所示......


if($row[1] == 'Tom') {

...当“while 循环”完成时,会创建一个如下所示的数组:


array(

'item_1' => array('id' => 2, 'name' => 'Tom', 'qty' => 3, 'price' => 36),

'item_2' => array('id' => 4, 'name' => 'Tom', 'qty' => 5, 'price' => 69),

'item_3' => array('id' => 6, 'name' => 'Tom', 'qty' => 2, 'price' => 75)

);

(第一个元素的“项目编号”需要以“item_1”开头,并在添加新元素时递增 1)。


如果这是可能的,需要使用什么逻辑?


繁星淼淼
浏览 101回答 1
1回答

蝴蝶不菲

只需将一个元素分配给结果数组即可。$result = [];$index = 1;$cols = fgetcsv($h, ","); // get header rowwhile (($row = fgetcsv($h, 10000, ",")) !== FALSE) {    if ($row[1] == 'Tom') {        $result['item_' . $index++] = array_combine($cols, $row);    }}
打开App,查看更多内容
随时随地看视频慕课网APP