我使用这段代码从CSV文件中获取列数:
$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)新行字符?
发布于 2011-01-21 14:27:17
来自manual
注意:如果PHP在Macintosh计算机上读取文件时没有正确识别行尾,启用auto_detect_line_endings运行时配置选项可能有助于解决问题。
发布于 2011-01-21 14:35:33
如果扫罗的答案不起作用,我会编写一个简单的脚本来同时读取文件,然后用\n将结果转储到一个新文件中,然后用str_replace \r对新文件进行fgetcsv‘处理。
我觉得有趣的是,这些术语来自于使用打字机的时代:
线馈电(LF)-推进纸张一行。
\r =回车(CR) -将运输返回到打字机的左侧。
https://stackoverflow.com/questions/4759880
复制相似问题