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


    使用CSV导入数据的时候,我们通常用的是Windows系统,使用GBK在Windows的Excel中编辑.

    但服务器上,很多使用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_fileiconv('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);
  • 相关阅读:
    SDOI2016游戏
    李超线段树
    SDOI2016数字配对
    SDOI2016储能表
    ! JOISC2020DAY3星座3
    JOISC2020DAY2有趣的 Joitter 交友
    第十天学习内容 函数
    第九天学习内容 结构体
    第八天学习内容 集合
    第七天学习内容 数组
  • 原文地址:https://www.cnblogs.com/heiing/p/2261351.html
Copyright © 2020-2023  润新知