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)."')";
}

これは1行だけを出力します。ここに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

これがなぜ起こっているのでしょうか?

ベストアンサー

ドキュメントから:

fgetcsv – ファイルポインタからを取得し、CSVフィールドを解析します

複数の行が必要な場合は、複数回呼び出す必要があります。

コメントする

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です