linux中fgetcsv取得的数组元素为空字符串的解决方法
发布:smiling 来源: PHP粉丝网 添加日期:2014-09-18 14:53:01 浏览: 评论:0
分享一篇关于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实例代码如下:
- // 上传的CSV文件,通常是用Excel编辑的GBK编码,
- // 而源代码是UTF-8,需要进行转码处理
- file_put_contents($new_file, iconv('GBK', 'UTF-8', file_get_contents($new_file)));//开源代码phpfensi.com
- //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);
Tags: linux空字符 fgetcsv数组元素为空
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)