读写文件时遇到编码问题解决方法
读取文件时有时候会遇到编码问题,导致读取的内容为乱码,此时我们可以用iconv来进行转码。
使用file_get_contents()来读取文件内容,但是有时候文件过大的话,就会导致内存溢出,读取失败,
此时使用逐行读取的方法;
$file = '1.txt';
$handle = fopen($file, 'r');
while (!feof($handle)) {
$line = fgets($handle);
$encoding = mb_detect_encoding($line, array('GB2312','GBK','UTF-16','UCS-2','UTF-8','BIG5','ASCII')); //识别内容是哪一种编码。如果知道编码就忽略这一步
$con = iconv($encoding,"UTF-8",$line);
echo $con;
}
或者可以在linux上直接先对文件进行转码
$ iconv -c -f EUC-CN -t utf8 1.txt -o 2.txt
选项注解
-f 原始文件编码
-c 忽略错误字符
-t 目标字符集
-o 输出文件
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步