加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

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

发布时间:2020-12-13 06:01:49 所属栏目:PHP教程 来源:网络整理
导读:但服务器上,很多使用Linux服务器,源程序使用UTF-8,这样很容易产生字符编码的问题. 如果仅仅将CSV文件转码为UTF-8,这样在Windows服务器上没有问题,而在RedHat5.5上,用fgetcsv取得的数组中,如果某列的内容是中文,则该列对应的数组元素为空字符串,而英文则正常.

但服务器上,很多使用Linux服务器,源程序使用UTF-8,这样很容易产生字符编码的问题. 如果仅仅将CSV文件转码为UTF-8,这样在Windows服务器上没有问题,而在RedHat5.5上,用fgetcsv取得的数组中,如果某列的内容是中文,则该列对应的数组元素为空字符串,而英文则正常. 这时,需要设置区域: setlocale(LC_ALL,'zh_CN.UTF-8');
代码如下
<div class="codetitle"><a style="CURSOR: pointer" data="44068" class="copybut" id="copybut44068" onclick="doCopy('code44068')"> 代码如下:<div class="codebody" id="code44068">
// 上传的CSV文件,通常是用Excel编辑的GBK编码,
// 而源代码是UTF-8,需要进行转码处理
file_put_contents($new_file,iconv('GBK','UTF-8',file_get_contents($new_file))); //ini_set('auto_detect_line_endings',true);
// 设置区域:简体中文,UTF-8编码
setlocale(LC_ALL,'zh_CN.UTF-8');
// 打开CSV文件
$handle = fopen($new_file,'r');
// 取出列头
$data_heads = fgetcsv($handle);

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读