这里只介绍比较常用的读取文件的常用方法:
1,file_get_contents,将一个文件内容读取到一个字符串中
// 读取整个文件
if(file_exists($filepath)){
// 例如:读取TXT文件
$str = file_get_contents($filepath);
// 编码转换
$str = iconv("gb2312","UTF-8",$str);
}
$filepath: 文件路径
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);
}
fopen: 打开文件或者url
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){...}