Linux fgetcsv取得的数组元素为空字符串的解决方法_php教程-查字典教程网
Linux fgetcsv取得的数组元素为空字符串的解决方法
Linux fgetcsv取得的数组元素为空字符串的解决方法
发布时间:2016-12-29 来源:查字典编辑
摘要:但服务器上,很多使用Linux服务器,源程序使用UTF-8,这样很容易产生字符编码的问题.如果仅仅将CSV文件转码为UTF-8,这样在Win...

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

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

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

这时,需要设置区域:

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

代码如下

复制代码 代码如下:

// 上传的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);

相关阅读
推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
  • 大家都在看
  • 小编推荐
  • 猜你喜欢
  • 最新php教程学习
    热门php教程学习
    编程开发子分类