首页 > 解决方案 > 在 laravel 中读取 CSV 文件时出现 UTF-8、二进制数据和特殊字符问题

问题描述

我正在使用 League/CSV Laravel 包来读取和操作 CSV 文件并将该 CSV 数据保存到数据库中,但是在从 CSV 读取数据时,我只遇到了一些行的问题,这些行只有一些特殊字符,如“45.6 ºF”。

我对这个问题进行了很多搜索,发现我们应该在数据库排序规则中使用“UTF-8”或“utf8mb4”并将该CSV也保存在“utf8”中,但它仅适用于键盘上的所有特殊字符.

我想使用键盘上没有的所有类型的特殊字符,例如“45.6 ºF”。

目前,我的代码正在读取 CSV 列数据并将其转换为二进制数据' b"column value" ' 它与字符串一起添加"b"并将该字符串转换为二进制值,仅用于那些具有任何特殊字符的字符串。

我花了很多时间,但找不到更好的解决这个问题的方法。所以请帮助我,我将非常感谢你。

 $reader = Reader::createFromPath(public_path().'/question.csv', 'r');
 $reader->setHeaderOffset(0);
 $records = $reader->getRecords();
 foreach ($records as $offset => $record) {
    $qs = Question::first();
    $qs->question =  $record['Question'];
    $qs->save();
 }

从带有“b”的 CSV 读取后,它给了我这个结果。

array:2 [▼
  "ID" => "1"
  "Question" => b"Fahrenheit to Celsius (ºF to ºC) conversion calculator for temperature conversions with additional tables and formulas"
]

但它应该是没有“b”二进制的字符串格式。

如果我用特殊字符复制该字符串并将其分配给静态变量,那么它可以正常工作并将数据保存到这样的数据库中

$a="Fahrenheit to Celsius (ºF to ºC) conversion calculator for temperature conversions with additional tables and formulas";

$qs = Question::first();
$qs->question =  $a;
$qs->save();

经过一番努力,我找到了解决这个问题的方法。我只是将这一行添加到代码中,以便在保存到数据库之前将其转换为utf8_encode 。

$r = array_map("utf8_encode", $record);

不要只是从谷歌复制粘贴文本以保存在数据库中,因为复制粘贴文本和特殊字符在大多数情况下都不起作用。

谢谢。

标签: phplaravelcsvfgetcsvutf8mb4

解决方案


我找到了解决这个问题的方法。下面的代码行解决了我的问题$r = array_map("utf8_encode", $record);我们只需要在保存到数据库之前转换成utf8_encode 。


推荐阅读