php文件 *** 作之逐行读取文件

php文件 *** 作之逐行读取文件,第1张

概述php文件 *** 作之逐行读取文件 在上一篇的文章《php文件 *** 作之逐个字符读取文件》中我们介绍了读取文件的一种方法:逐个字符读取文件。本篇文章我们再带大家了解一种读取文件的方法:逐行读取文件,看看如何逐行读取文件内容并输出,一起来学习吧。

有一个名为“test.txt”的文本文件,里面的内容为:

我们如何逐行读取文件中的内容并输出?简单,今天我们就来给大家介绍两种方法。

方法1:使用fgets()函数

我们来看看代码示例:

<?PHPheader("Content-Type: text/HTML;charset=utf-8");    //设置字符编码$handle = fopen('./test.txt', 'r');                 //打开文件if (!$handle) {                                     //判断文件是否打开成功    echo '文件打开失败!';}while (false !== ($char = fgets($handle,1024))) {        //循环读取文件内容    echo $char."<br>";}fclose($handle);                                    //关闭文件?>

输出结果:

关键函数分析:

fgets()函数用于从打开的文件中读取一行数据,接受一个必需参数$file(被打开的文件)和一个可选参数$length(要读取的字节数);如果省略了 $length 参数,则默认读取 1k(即1024字节)长度。

fgets()函数在遇到换行符EOF(读到文件末尾)或者到达指定长度 $length-1 后停止(返回字符串长度最大值为 $length-1 个字节)。

如果我们不知道文件中有多少数据,可以使用filesize()函数来获取,该函数可以返回指定文件的大小(字节数)。

所以上面的代码示例可以修改一下:

<?PHPheader("Content-Type: text/HTML;charset=utf-8");    //设置字符编码$url = './test.txt';$handle = fopen($url, 'r');                 //打开文件 $size= filesize($url);                  //计算文件大小if (!$handle) {                                     //判断文件是否打开成功    echo '文件打开失败!';}while (false !== ($char = fgets($handle,$size))) {        //循环读取文件内容    echo $char."<br>";}fclose($handle);                                    //关闭文件?>

输出结果和上面是一样的。

方法2:使用fgetss()函数

我们来看看代码示例:

<?PHPheader("Content-Type: text/HTML;charset=utf-8");    //设置字符编码$handle = fopen('./test.txt', 'r');                 //打开文件if (!$handle) {                                     //判断文件是否打开成功    echo '文件打开失败!';}while (false !== ($char = fgetss($handle,1024))) {        //循环读取文件内容    echo $char."<br>";}fclose($handle);                                    //关闭文件?>

输出结果:

关键函数分析:

fgetss()函数和fgets()函数相似,都可以从打开的文件中读取一行数据,不同的是fgetss()函数会过滤掉数据中的 HTML 和 PHP 标签。

fgetss() 函数接受一个必需参数$file、两个可选参数$length$Tags。参数$file和$length在fgets()函数中介绍过来,大家可以去上文了解。而参数$Tags是用来指定哪些标记不被去掉,我们通过一个例子来具体了解一下:

<?PHPheader("Content-Type: text/HTML;charset=utf-8");    //设置字符编码$handle = fopen('./test.txt', 'r');                 //打开文件if (!$handle) {                                     //判断文件是否打开成功    echo '文件打开失败!';}while (false !== ($char = fgetss($handle,1024,"<h1>,<em>"))) {        //循环读取文件内容    echo $char."<br>";}fclose($handle);                                    //关闭文件?>

在上面的代码中,我们设置参数$Tags的值为“<h1>,<em>”,也就是不过滤<h1><em>标签,因此输出结果:

注意:在 *** 作完文件后,要记得使用fclose()函数来关闭文件!

好了就说到这里了,有其他想知道的,可以点击这个哦。→ →PHP文件基础 *** 作

推荐:《PHP面试题大汇总(收藏)》《php视频教程》 总结

以上是内存溢出为你收集整理的php文件 *** 作之逐行读取文件全部内容,希望文章能够帮你解决php文件 *** 作之逐行读取文件所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1153624.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存