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

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

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

  2021-03-18 我要评论
想了解Linux fgetcsv取得的数组元素为空字符串的解决办法的相关内容吗,在本文为您仔细讲解Linux fgetcsv的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:Linux,fgetcsv,下面大家一起来学习吧。
但服务器上,很多使用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);

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们