我有一个简单的CSV文件正在生成,其中包括外国字符。我已经注意到,如果我不包括字节顺序标记,则外部字符不会在Excel中正确显示(但当存在BOM时,它们显示正常)。
在第一次创建文件时,如何将BOM添加到文件的开头?我尝试了以下方法,但不起作用:-/
function processForm($competition, $competitionEntry) {
$BOM = "\xEF\xBB\xBF"; // UTF-8 BOM
$filename = $competition->ID.".csv";
$file = "entries/".$filename;
$fields = array_keys($competitionEntry);
$submittedForm = $competitionEntry;
if(file_exists($file)) {
$fp = fopen($file, 'a');
if($fp &&
fputcsv($fp, $submittedForm) &&
fclose($fp)) {
return true;
}
} else { // CREATE NEW FILE
$fp = fopen($file, 'w');
if($fp &&
fputcsv($fp, $BOM) && // WRITE BOM TO FILE
fputcsv($fp, $fields) &&
fputcsv($fp, $submittedForm) &&
fclose($fp)) {
return true;
}
}
return false;
}发布于 2014-09-09 01:31:27
感谢Mark Baker的回答:
我需要使用fwrite()来添加BOM,而不是fputcsv()。
工作版本如下所示:
if(file_exists($file)) {
$fp = fopen($file, 'a');
if($fp &&
fputcsv($fp, $submittedForm) &&
fclose($fp)) {
return true;
}
} else {
$fp = fopen($file, 'w');
fwrite($fp, $BOM); // NEW LINE
if($fp &&
fputcsv($fp, $fields) &&
fputcsv($fp, $submittedForm) &&
fclose($fp)) {
return true;
}
}谢谢,马克!
https://stackoverflow.com/questions/25686191
复制相似问题