用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

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

时间:2015-01-23  来源:西部数据  作者:西部数据

分享一篇关于linux中fgetcsv取得的数组元素为空字符串的解决方法的教程,有需要的朋友可以参考一下.

使用CSV导入数据的时候,我们通常用的是Windows系统,使用GBK在Windows的Excel中编辑.但服务器上,很多使用Linux服务器,源程序使用UTF-8,这样很容易产生字符编码的问题.如果仅仅将CSV文件转码为UTF-8,这样在Windows服务器上没有问题,而在RedHat5.5上,用fgetcsv取得的数组中,如果某列的内容是中文,则该列对应的数组元素为空字符串,而英文则正常.这时,需要设置区域如下:

setlocale(LC_ALL, 'zh_CN.UTF-8');

PHP实例代码如下:

  1. // 上传的CSV文件,通常是用Excel编辑的GBK编码, 
  2. // 而源代码是UTF-8,需要进行转码处理 
  3. file_put_contents($new_file, iconv('GBK''UTF-8'file_get_contents($new_file)));//开源代码phpfensi.com 
  4.  
  5. //ini_set('auto_detect_line_endings', true); 
  6. // 设置区域:简体中文,UTF-8编码 
  7. setlocale(LC_ALL, 'zh_CN.UTF-8'); 
  8. // 打开CSV文件 
  9. $handle = fopen($new_file'r'); 
  10. // 取出列头 
  11. $data_heads = fgetcsv($handle);
来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
    无相关信息
栏目更新
栏目热门