找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1332|回复: 0
打印 上一主题 下一主题

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

[复制链接]

2647

主题

2647

帖子

7881

积分

论坛元老

Rank: 8Rank: 8

积分
7881
跳转到指定楼层
楼主
发表于 2018-2-14 08:32:03 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            但服务器上,很多使用Linux服务器,源程序使用UTF-8,这样很容易产生字符编码的问题.
如果仅仅将CSV文件转码为UTF-8,这样在Windows服务器上没有问题,
而在RedHat5.5上,用fgetcsv取得的数组中,如果某列的内容是中文,则该列对应的数组元素为空字符串,而英文则正常.
这时,需要设置区域:
setlocale(LC_ALL, 'zh_CN.UTF-8');
代码如下
[U]复制代码[/U] 代码如下:
// 上传的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 bash字符串处理大全
  • Linux shell脚本中字符串连接的方法
  • 利用PHP脚本在Linux下用md5函数加密字符串的方法
  • linux shell 字符串操作(长度,查找,替换)详解
  • linux shell字符串内置的常用操作(获取长度、查找、替换)
  • Linux C字符串替换函数实例详解
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端