我有一个PHP网站和一个cron作业,它运行来更新该网站的数据库。cron读取由第三方上传的CSV文件。最近,此cron作业停止正常工作。经过一番调查,我发现问题出在CSV文件中。问题是CSV中的新行字符已经从标准的"\n“更改为旧的ASCII "^M”,PHP似乎不会将其识别为新行,因此它不会将CSV视为多行,而是将其视为单行信息。我只能在命令行文本应用程序less和vim中看到这种差异。有没有人知道一种让PHP识别这些换行符的方法?
举个例子,不正确的CSV文件在vim中看起来像这样:
Heading 1,Heading 2,Heading 3,^MInfo 1-1,Info 1-2,Info 1-3,^MInfo 2-1,Info 2-2,Info 2-3,^M^M而较早的(正确的)版本在vim中显示如下:
Heading 1,Heading 2,Heading 3,
Info 1-1,Info 1-2,Info 1-3,
Info 2-1,Info 2-2.Info 2-3,发布于 2012-04-30 23:41:13
适当设置auto_detect_line_endings选项。
发布于 2012-04-30 23:42:14
您可以不更改代码以查找^M或将^M替换为\n吗?
str_replace("^M", "\n", $input);https://stackoverflow.com/questions/10386374
复制相似问题