我正在尝试导入一个通过Microsoft Excel保存为csv的php中的csv。我试图同时使用fopen和fgetcsv。
我注意到通过调试excel在导出为csv时没有在文件上保存字符集,因此php假设该文件是ascii并且正在尝试删除/转换任何非ascii字符(例如:é, î,è)到布尔。
导入具有非ascii字符的csv而不必删除非ascii字符的最佳方法是什么?
----------编辑--------------
<?php
try{
ini_set('auto_detect_line_endings', true);
$file = $_FILES['file'] ['tmp_name'];
$handle = fopen($_FILES['file']['tmp_name'], 'r');
while (($data = fgetcsv($handle)) !== false) {
foreach ($data as $d) {
Log::info($d);
}
}
fclose($handle);
}catch(\Exception $e){
abort(500, $e->getMessage());
}
然后使用与上面相同的功能(我拿出了一些额外的代码,所以我不是100%确定这段代码正常运行)任何不是ASCII的字符都被转换为布尔值,无论如何都很好, php(laravel)错误输出,因为boolean不是响应对象上json_encode的_toString类型。