Linux fgetcsv取得的数组元素为空字符串的解决方法

前端之家收集整理的这篇文章主要介绍了Linux fgetcsv取得的数组元素为空字符串的解决方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

但服务器上,很多使用Linux服务器,源程序使用UTF-8,这样很容易产生字符编码的问题. 如果仅仅将CSV文件转码为UTF-8,这样在Windows服务器上没有问题,而在RedHat5.5上,用fgetcsv取得的数组中,如果某列的内容中文,则该列对应的数组元素为空字符串,而英文则正常. 这时,需要设置区域: setlocale(LC_ALL,'zhCN.UTF-8'); @H301_0@代码如下 @H_301_0@<div class="codetitle"><a style="CURSOR: pointer" data="44068" class="copybut" id="copybut44068" onclick="doCopy('code44068')"> 代码如下:

<div class="codebody" id="code44068"> @H_301_0@// 上传的CSV文件,通常是用Excel编辑的GBK编码,@H_301_0@// 而源代码是UTF-8,需要进行转码处理 @H_301_0@file_put_contents($new_file,iconv('GBK','UTF-8',file_get_contents($new_file))); //ini_set('auto_detect_lineendings',true); @H301_0@// 设置区域:简体中文,UTF-8编码 @H_301_0@setlocale(LC_ALL,'zhCN.UTF-8'); @H301_0@// 打开CSV文件 @H_301_0@$handle = fopen($newfile,'r'); @H3010@// 取出列头 @H301_0@$dataheads = fgetcsv($handle); @H301_0@

猜你在找的PHP相关文章