Linux fgetcsv取得的数组元素为空字符串的解决方法
程序员文章站
2022-06-03 10:29:12
但服务器上,很多使用linux服务器,源程序使用utf-8,这样很容易产生字符编码的问题. 如果仅仅将csv文件转码为utf-8,这样在windows服务器上没有问题, 而...
但服务器上,很多使用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);
如果仅仅将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);
推荐阅读
-
Linux fgetcsv取得的数组元素为空字符串的解决方法
-
Linux fgetcsv取得的数组元素为空字符串的解决方法
-
Linux fgetcsv取得的数组元素为空字符串的解决方法_PHP教程
-
Linux fgetcsv取得的数组元素为空字符串的解决方法
-
Linux fgetcsv取得的数组元素为空字符串的解决方法_php技巧
-
linux中fgetcsv取得的数组元素为空字符串的解决方法_PHP教程
-
Linux fgetcsv取得的数组元素为空字符串的解决方法_php技巧
-
linux中fgetcsv取得的数组元素为空字符串的解决方法_PHP教程
-
linux中fgetcsv取得的数组元素为空字符串的解决方法
-
Linux fgetcsv取得的数组元素为空字符串的解决方法_PHP