fgets
(PHP 4, PHP 5, PHP 7, PHP 8)
fgets — 从文件指针中读取一行
说明
fgets
( resource
$handle
, int $length
= ?
) : string从文件指针中读取一行。
参数
-
handle
-
文件指针必须是有效的,必须指向由 fopen() 或 fsockopen() 成功打开的文件(并还未由 fclose() 关闭)。
-
length
-
从
handle
指向的文件中读取一行并返回长度最多为length
- 1 字节的字符串。碰到换行符(包括在返回值中)、EOF 或者已经读取了 length - 1 字节后停止(看先碰到那一种情况)。如果没有指定length
,则默认为 1K,或者说 1024 字节。
返回值
从指针 handle
指向的文件中读取了 length
- 1 字节后返回字符串。
如果文件指针中没有更多的数据了则返回 false
。
错误发生时返回 false
。
范例
示例 #1 逐行读取文件
<?php
$handle = @fopen("/tmp/inputfile.txt", "r");
if ($handle) {
while (($buffer = fgets($handle, 4096)) !== false) {
echo $buffer;
}
if (!feof($handle)) {
echo "Error: unexpected fgets() fail\n";
}
fclose($handle);
}
?>
注释
注意: 在读取在 Macintosh 电脑中或由其创建的文件时, 如果 PHP 不能正确的识别行结束符,启用运行时配置可选项 auto_detect_line_endings 也许可以解决此问题。
注意:
习惯了 C 语言中 fgets() 语法的人应该注意到
EOF
是怎样被返回的。
参见
- fgetss() - 从文件指针中读取一行并过滤掉 HTML 标记
- fread() - 读取文件(可安全用于二进制文件)
- fgetc() - 从文件指针中读取字符
- stream_get_line() - 从资源流里读取一行直到给定的定界符
- fopen() - 打开文件或者 URL
- popen() - 打开进程文件指针
- fsockopen() - 打开一个网络连接或者一个Unix套接字连接
- stream_set_timeout() - Set timeout period on a stream