array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'ja', ), 'this' => array ( 0 => 'function.fgets.php', 1 => 'fgets', ), 'up' => array ( 0 => 'ref.filesystem.php', 1 => 'ファイルシステム 関数', ), 'prev' => array ( 0 => 'function.fgetcsv.php', 1 => 'fgetcsv', ), 'next' => array ( 0 => 'function.fgetss.php', 1 => 'fgetss', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'ja', 'path' => 'reference/filesystem/functions/fgets.xml', ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); ?>
(PHP 4, PHP 5, PHP 7, PHP 8)
fgets — ファイルポインタから 1 行取得する
stream
ファイルポインタは、有効なファイルポインタである必要があり、 fopen() または fsockopen() で正常にオープンされた (そしてまだ fclose() でクローズされていない) ファイルを指している必要があります。
length
読み出しは、length
- 1
バイト読み出したか、(戻り値に含まれる)
改行文字を検出したか、EOF に達したかのいずれかが起こった時点で終了します。
length が指定されない場合は、行末に達するまで読み続けます。
stream
で指定したファイルポインタから最大
length
- 1 バイト読み出し、
その文字列を返します。ファイルポインタから読み込むデータがもうない場合は
false
を返します。
エラーが起こった場合、false
を返します。
例1 行毎にファイルを読み込む
<?php
$fp = @fopen("/tmp/inputfile.txt", "r");
if ($fp) {
while (($buffer = fgets($fp, 4096)) !== false) {
echo $buffer;
}
if (!feof($fp)) {
echo "Error: unexpected fgets() fail\n";
}
fclose($fp);
}
?>
注意: マッキントッシュコンピュータ上で作成されたファイルを読み込む際に、
PHP
が行末を認識できないという問題が発生した場合、 実行時の設定オプションauto_detect_line_endings を有効にする必要が生じるかもしれません。
注意:
C 言語の fgets() の動作に慣れている人は、
EOF
を返す条件の違いについて注意する必要があります。