【发布时间】:2012-08-04 20:27:15
【问题描述】:
我有一个我无法控制的来源下载的 CSV,每行的结尾都是一个
^M
打印到 bash 终端时的字符。如何在 PHP 中以编程方式清理此输入?
【问题讨论】:
我有一个我无法控制的来源下载的 CSV,每行的结尾都是一个
^M
打印到 bash 终端时的字符。如何在 PHP 中以编程方式清理此输入?
【问题讨论】:
您看到的是一个 Windows 控制字符。要在 PHP 中摆脱这种情况,您需要做的是
$file = str_ireplace("\x0D", "", $file)
无论十六进制是小写还是大写,这都会起作用。
【讨论】:
^M 是 carriage return,您应该可以使用以下命令将其删除:
$string = str_replace( "\r", "", $string);
【讨论】:
您也可以要求 PHP 自动检测任何奇怪的行结尾,只需在读取 CSV 文件之前添加此行,您将无需执行任何其他操作。
ini_set('auto_detect_line_endings', true);
【讨论】: