8

我正在尝试使用 fgetCsv 但由于某种原因它只读取第一行。这是代码:

$fieldseparator = ",";
$lineseparator = "\r";


if(!file_exists($csvFile)) {
    echo "<div id='error'>Cannot find uploaded file. Please try again</div>";
    exit;
}

$file = fopen($csvFile,"r");

if(!$file) {
    echo "<div id='error'>Error loading CSV file</div>";
    exit;
}

$size = filesize($csvFile);
if(!$size) {
    echo "<div id='warning'>File is empty</div>";
    exit;
}

$query = "";
$content = fgetcsv($file,$size,$lineseparator);


fclose($file);

foreach($content as $data) {
        $values = explode($fieldseparator,$data);
        $query[$i] = "('".implode("','",$values)."')";
}

这只是输出一行。这是 CSV 文件:

TSE-P01,1,WO47653897,RM,EcoQuiet,1
TSE-P02,1,WO47653898,RM,EcoQuiet,1
TSE-P03,1,WO47653899,RM,EcoQuiet,1
TSE-P04,1,WO47653900,RM,EcoQuiet,1
TSE-P05,1,WO47653901,RM,EcoQuiet,1
TSE-P06,1,WO47653902,RM,EcoQuiet,1
TSE-P07,1,WO47653903,RM,EcoQuiet,1
TSE-P08,1,WO47653904,RM,EcoQuiet,1

任何想法为什么会发生这种情况?

4

2 回答 2

10

文档

fgetcsv — 从文件指针获取并解析 CSV 字段

如果您想要多条线路,则需要多次调用它。

于 2011-11-12T21:20:57.450 回答
8

此示例是来自 w3schools http://www.w3schools.com/php/func_filesystem_fgetcsv.asp的“示例 2”

$file = fopen("contacts.csv","r");

while(!feof($file))
  {
  print_r(fgetcsv($file));
  }

fclose($file);

使用while循环代码遍历整个文件/所有行..

或者..如果你做这样的事情..

print_r(fgetcsv($file));
print_r(fgetcsv($file));
print_r(fgetcsv($file));

它只会打印前 3 行..

于 2014-01-29T11:58:27.670 回答