首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何使PHP的fgetcsv()识别经典Mac (CR)的新行字符?

如何使PHP的fgetcsv()识别经典Mac (CR)的新行字符?
EN

Stack Overflow用户
提问于 2011-01-21 14:24:34
回答 2查看 4.7K关注 0票数 8

我使用这段代码从CSV文件中获取列数:

代码语言:javascript
运行
复制
$this->dummy_file_handler = fopen($this->config['file'],'r');
if ($dataset =fgetcsv($this->dummy_file_handler))
{
    $this->number_of_columns = count($dataset);
}

除非使用ExcelforMac2011导出文件,否则工作得很好,因为新的行字符是经典Mac (CR),fgetcsv不识别。

如果我手动将换行符从经典Mac (CR)更改为Unix (LR),那么它可以工作,但我需要将其自动化。

如何使fgetcsv 识别经典Mac (CR)新行字符?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-01-21 14:27:17

来自manual

注意:如果PHP在Macintosh计算机上读取文件时没有正确识别行尾,启用auto_detect_line_endings运行时配置选项可能有助于解决问题。

票数 20
EN

Stack Overflow用户

发布于 2011-01-21 14:35:33

如果扫罗的答案不起作用,我会编写一个简单的脚本来同时读取文件,然后用\n将结果转储到一个新文件中,然后用str_replace \r对新文件进行fgetcsv‘处理。

我觉得有趣的是,这些术语来自于使用打字机的时代:

线馈电(LF)-推进纸张一行。

\r =回车(CR) -将运输返回到打字机的左侧。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4759880

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档