这里只介绍比较常用的读取文件的常用方法:
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){...}
|