我正在尝试导入一个通过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) )错误输出,因为布尔值不是响应对象上的json_encode类型_toString .