php提供五种按行读取文本文件的方法:一、fgets()逐行读取,内存占用低;二、file()一次性加载为数组,适合中小文件;三、splfileobject面向对象迭代;四、stream_get_line()自定义分隔符读取;五、generator生成器实现内存友好型逐行迭代。

如果您需要在PHP中处理文本文件,并希望逐行获取内容以避免内存占用过高,则可以采用多种内置函数实现按行读取。以下是几种常用且可靠的方法:
一、使用fgets()函数逐行读取
fgets()函数从文件指针中读取一行,包括换行符,直到遇到换行符、EOF或读取指定长度(默认为整行)为止。该方法内存占用低,适合处理大文件。
1、使用fopen()打开文件,指定只读模式("r")。
2、使用while循环配合fgets()持续读取每一行,直到返回false(表示文件末尾)。
立即学习“PHP免费学习笔记(深入)”;
3、在每次循环中对当前行进行trim()处理,去除行首行尾空白及换行符。
4、使用fclose()关闭文件指针,释放资源。
二、使用file()函数一次性读取并遍历
file()函数将整个文件读入数组,每行为一个数组元素。虽非真正“流式”读取,但语法简洁,适用于中小文件且需随机访问行号的场景。
1、调用file()函数传入文件路径,设置FILE_IGNORE_NEW_LINES和FILE_SKIP_EMPTY_LINES标志以自动过滤空行和换行符。
2、使用foreach循环遍历返回的数组,逐个处理每一行。
3、注意:该方法会将全部内容载入内存,不建议用于大于几十MB的文件。
三、使用SplFileObject类面向对象方式读取
SplFileObject是PHP标准库提供的迭代器类,支持以面向对象形式逐行遍历,具备seek()、key()、current()等方法,便于控制读取位置与状态。
1、实例化SplFileObject对象,传入文件路径作为构造参数。
2、使用foreach循环直接遍历该对象,每轮返回当前行内容。
3、可调用setFlags()方法设置标志位,例如SplFileObject::SKIP_EMPTY | SplFileObject::READ_AHEAD,提升读取效率。
4、该对象在超出作用域时自动关闭文件,无需手动调用fclose()。
四、使用stream_get_line()配合自定义分隔符读取
stream_get_line()允许指定分隔符(如"\n")来截取行内容,不包含分隔符本身,适合需要精确控制行边界或处理非标准换行符(如"\r\n"、"\r")的场景。
1、使用fopen()打开文件并获取资源句柄。
2、在while循环中调用stream_get_line(),传入句柄、最大读取长度和分隔符字符串。
3、当返回为空字符串且feof()为true时,判定读取完成。
4、注意:该函数不会自动跳过空行,需自行判断strlen()结果是否为0。
五、使用PHP 7.4+的generator实现内存友好型逐行迭代
通过yield关键字定义生成器函数,可在不加载全文的前提下,对外暴露一个可遍历的行序列,极大降低内存压力,尤其适合超大日志文件分析。
1、定义一个带yield的函数,接收文件路径参数。
2、在函数内使用fopen()和fgets()组合循环读取,每读一行即yield返回。
3、在调用处使用foreach遍历该生成器函数的返回值。
4、生成器内部无需显式fclose(),但建议在finally块中关闭句柄以确保资源释放,否则可能导致文件句柄泄露。










