首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >fGetCsv只读第一行?

fGetCsv只读第一行?
EN

Stack Overflow用户
提问于 2011-11-13 05:17:29
回答 2查看 11.7K关注 0票数 7

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

代码语言:javascript
复制
$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文件:

代码语言:javascript
复制
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

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

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-11-13 05:20:57

来自the docs

CSV从文件指针获取,并解析

字段

如果您想要多行,则需要多次调用它。

票数 10
EN

Stack Overflow用户

发布于 2014-01-29 19:58:28

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

代码语言:javascript
复制
$file = fopen("contacts.csv","r");

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

fclose($file);

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

或者..。如果你做了那样的事..

代码语言:javascript
复制
print_r(fgetcsv($file));
print_r(fgetcsv($file));
print_r(fgetcsv($file));

它将只打印前3行。

票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8107628

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档