php - fGetCsv 只读第一行?

标签 php csv fgetcsv

我正在尝试使用 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

知道为什么会发生这种情况吗?

最佳答案

来自 the docs :

fgetcsv — Gets line from file pointer and parse for CSV fields

如果你想要多条线路,那么你需要多次调用它。

关于php - fGetCsv 只读第一行?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8107628/

相关文章:

php - 发送 HTTP 响应后继续 PHP 执行

php - 像 Ã 这样的字符在 MySQL 中无法正确显示

java - 为什么 Scala 在读取我的 CSV 时会崩溃?

php - fgetcsv() 为每一行返回 "true"

php - 如何在读取 fgetcsv 时删除数据库中存储的双引号

image - 代码发送了 2 次,但没有正确的图像

PHP:调用未定义函数:simplexml_load_string()

c++ - 如何在 Armadillo csv文件中写入标题?

python - 从文件中读取的 CSV 分隔符

php - 为什么这个 PDO Insert 执行了两次?