PHP读取TXT中文乱码的解决方式

添加时间:17-06-28 所属分类:PHP工具与代码
  https://my.oschina.net/landry17h/blog/17145

因为业务上的需求,需要使用PHP读取一个TXT文件,但是在设计到中文的问题上,就遇到了恶心的乱码问题;
首先查看一下TXT的编码格式有四种:ANSI、Unicode、Unicode Big Endian、UTF-8

1、先是使用mb_detect_encoding($contents, array('GB2312','GBK','UTF-16','UCS-2','UTF-8','BIG5','ASCII'))语句
发现即使在其中增加了Unicode格式,已经无法获得文件的编码格式,但是对与ANSI和UTF-8格式倒是可以使用;

2、于是针对这个问题,专门做了一个如下的转换:
[code]
$str = mb_convert_encoding ( $str, 'UTF-8','Unicode');[/code]

只是需要在前面加上一个编码格式的判断。



完整代码如下:
[code]
if ($fname = $_FILES['nickname']['tmp_name']) {

//获取文件的编码方式

$contents = file_get_contents($fname);

$encoding = mb_detect_encoding($contents, array('GB2312','GBK','UTF-16','UCS-2','UTF-8','BIG5','ASCII'));



$fp=fopen($fname,"r");//以只读的方式打开文件

$text = "";

$num = 0;

if(!(feof($fp))) {

$num++;

$str = trim(fgets($fp));

if ($encoding != false) {

$str = iconv($encoding, 'UTF-8', $str);

if ($str != "" and $str != NULL) {

$text = $str;

}

}

else {

$str = mb_convert_encoding ( $str, 'UTF-8','Unicode');

if ($str != "" and $str != NULL) {

$text = $str;

}

}

}

while(!(feof($fp))) {

$str = '';

$str = trim(fgets($fp));

if ($encoding != false) {

$str = iconv($encoding, 'UTF-8', $str);

if ($str != "" and $str != NULL) {

$text = $text.",".$str;

}

}

else {

$str = mb_convert_encoding ( $str, 'UTF-8','Unicode');

if ($str != "" and $str != NULL) {

$text = $text.",".$str;

}

}

}

}[/code]

前篇:马琛琛:诚信经营 她要做济南的“老干妈” 后篇:PHP读取文本文件时汉字显示乱码的处理方法
发表我的评论


推荐文章   巴西女子不惧面部胎记拍自信写真   第一代农民工近暮年:要干到70岁 不干没...   孩子落户上学,济南通讯录   济南:27岁女孩酷爱钩编,手工作品已达...   济南市中区“一校一品”体育成果展精彩...
随机文章   流行的开源PHP框架排行榜   php class类用法总结   一篇入门的php Class 文章   UTF-8、GB2312都支持的汉字截取函数   用php将字符串转换成数组
广告

其他推荐

因为本站所有内容均转载自其它媒体,本意为公众提供免费服务,但并不代表本网赞同其观点,也不能对其真实性验证负责,如稿件版权单位或个人不想在本网发布,请与我联系,本人会立即将其撤除,谢谢.联系方式:atseashawk@163.com QQ:99289555