您好,欢迎访问一九零五行业门户网

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

分享一篇关于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))); //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);
本文地址:
转载随意,但请附上文章地址:-)
其它类似信息

推荐信息