为了账号安全,请及时绑定邮箱和手机立即绑定

自动将 CSV 从 iso-8859-2 转换为 utf-8

自动将 CSV 从 iso-8859-2 转换为 utf-8

PHP
九州编程 2022-07-22 16:38:54
我有很多 CSV 文件不幸用 iso-8859-2 编码(根据括号)。我想用 PHP 遍历这些文件并转换它们。我找到了https://csv.thephpleague.com/9.0/converter/charset/但我不确定使用转换功能的方式。他们的示例代码use League\Csv\CharsetConverter;$csv = new SplFileObject('/path/to/french.csv', 'r');$csv->setFlags(SplFileObject::READ_CSV | SplFileObject::SKIP_EMPTY);$encoder = (new CharsetConverter())->inputEncoding('iso-8859-15');$records = $encoder->convert($csv);到目前为止,这是我的代码,它是上传一个文件并将内容保存到数据库进行测试的表单的一部分。它当然会以不正确的格式保存文本。$db = ConnectDB::getConnection('address_dtb');$sql = " ... ";$stmt = $db->prepare($sql);$rowCount = 0;$temp_name = $_FILES['adresscsv']['tmp_name'];$file_handle = fopen($temp_name, 'r');while (($items = fgetcsv($file_handle, 1000, ';')) !== FALSE) {    if($flag) { $flag = false; continue; }    $stmt->execute($items);    $rowCount++;}fclose($file_handle);ConnectDB::closeConnection($db);使用上面的 PHP CSV 库在循环中迭代本地保存的文件for以自动化该过程的正确方法是什么?
查看完整描述

2 回答

?
慕少森

TA贡献2019条经验 获得超9个赞

您不必使用库。PHP中有一个函数可以做到这一点iconv


查看完整回答
反对 回复 2022-07-22
?
婷婷同学_

TA贡献1844条经验 获得超8个赞

我最终iconv按照提示使用。


$files = glob('address/*.csv');


foreach ($files as $csv) {

    $file_data = file_get_contents($csv);

    $utf8_file_data = iconv('Windows-1250', 'UTF-8', $file_data);

    file_put_contents($csv, $utf8_file_data);

}


查看完整回答
反对 回复 2022-07-22
  • 2 回答
  • 0 关注
  • 142 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信