使用具有特殊字符的PHP导入Excel CSV

时间:2017-02-28 20:33:04

标签: php excel csv character-encoding fgetcsv

我正在尝试导入一个通过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类型。

0 个答案:

没有答案