免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2165 | 回复: 0
打印 上一主题 下一主题

Linux中,fgetcsv取得的数组元素为空字符串的解决方法 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-11-24 17:02 |只看该作者 |倒序浏览
Linux中,fgetcsv取得的数组元素为空字符串的解决方法







使用CSV导入数据的时候,我们通常用的是Windows系统,使用GBK在Windows的Excel中编辑.

但服务器上,很多使用Linux服务器,源程序使用UTF-8,这样很容易产生字符编码的问题.

如果仅仅将CSV文件转码为UTF-8,这样在Windows服务器上没有问题,

而在RedHat5.5上,用fgetcsv取得的数组中,如果某列的内容是中文,则该列对应的数组元素为空字符串,而英文则正常.

这时,需要设置区域:  

setlocale(LC_ALL, 'zh_CN.UTF-8');
代码如下

  1. // 上传的CSV文件,通常是用Excel编辑的GBK编码,
  2. // 而源代码是UTF-8,需要进行转码处理
  3. file_put_contents($new_file, iconv('GBK', 'UTF-8', file_get_contents($new_file)));

  4. //ini_set('auto_detect_line_endings', true);
  5. // 设置区域:简体中文,UTF-8编码
  6. setlocale(LC_ALL, 'zh_CN.UTF-8');
  7. // 打开CSV文件
  8. $handle = fopen($new_file, 'r');
  9. // 取出列头
  10. $data_heads = fgetcsv($handle);
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP