这里只介绍比较常用的读取文件的常用方法:
1,file_get_contents,将一个文件内容读取到一个字符串中
// 读取整个文件 if(file_exists($filepath)){ // 例如:读取TXT文件 $str = file_get_contents($filepath); // 编码转换 $str = iconv("gb2312","UTF-8",$str); }
file_exists: 判断文件是否存在
iconv: 转换字符编码
当然 file_get_contents 也可以接受读取一个 url ,获取 url 中的文件内容.
2,fopen,基于此函数的相关读取方式
2.1,常用的逐行读取文件
if(file_exists($filepath)){ if ($file_handle = fopen($filepath, "r")) { // 只读方式 // 逐行读取 while (!feof($file_handle)) { $str .= fgetss($file_handle).'<br />'; } fclose($file_handle); } $str = iconv("gb2312","UTF-8",$str); }
feof(): 检测文件是否已经到达末尾
fgetss: 从打开的文件中读取一行并过滤掉 html,php 标记(与fgets相同除了过滤标记)
fclose: 关闭文件流
2.2,利用fread
fread 适合从二进制文件中读取信息,必须指定需要读入的字节数.
$fh = fopen("filepath", "rb"); $res= fread($file_handle, 1024);
这段代码将读取1024 字节 (1kb) 的数据(fread
不会读取超过 8192个字节,8kb的数据)。
文件过大只能采取循环读取,可以根据 filesize 这一函数进行判断,if(filesize("filepath") > 8192){...}
以上是PHP教程之文件读取教程的详细内容。更多信息请关注PHP中文网其他相关文章!