加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php – 如何为CSV,fgetcsv()问题转义逗号

发布时间:2020-12-13 17:45:05 所属栏目:PHP教程 来源:网络整理
导读:我在 PHP中使用fgetcsv()函数来读取使用Microsoft Excel生成的CSV文件. 问题是CSV文件包含带逗号的值,它按原样读取转义值(带双引号). 例如:“2,5,7”读作“2 5 8” 通过将双引号更改为单引号可以解决该问题.但是,我不想每次都编辑每个CSV文件. 我使用的代码
我在 PHP中使用fgetcsv()函数来读取使用Microsoft Excel生成的CSV文件.

问题是CSV文件包含带逗号的值,它按原样读取转义值(带双引号).

例如:“2,5,7”读作“2& 5& 8”

通过将双引号更改为单引号可以解决该问题.但是,我不想每次都编辑每个CSV文件.

我使用的代码如下:

$handle = fopen($path,"r");
$data = fgetcsv($handle,1000,","'");
do
{
    **READ CSV**
}
while ($data = fgetcsv($handle,5000,"));

处理这个问题的最佳方法是什么?

解决方法

改变这一行

$data = fgetcsv($handle,"'");

$data = fgetcsv($handle,'"');

或者只是取消最后两个参数,因为它们是默认值

$data = fgetcsv($handle,1000);

fgetcsv的第四个参数是外壳字符,它告诉如何构造可能在其中包含分隔符的字段.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读