linux如何判断数组是否为空,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);

本文地址:

转载随意,但请附上文章地址:-)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值