【问题标题】:Automating CSV conversion from iso-8859-2 to utf-8自动将 CSV 从 iso-8859-2 转换为 utf-8
【发布时间】:2020-01-16 09:21:45
【问题描述】:

不幸的是,我有很多 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 循环中迭代本地保存的文件以自动执行该过程的正确方法是什么?

【问题讨论】:

    标签: php csv character-encoding


    【解决方案1】:

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

    【讨论】:

      【解决方案2】:

      我最终按照提示使用了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);
      }
      

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 2018-07-06
        • 1970-01-01
        • 1970-01-01
        • 2013-07-03
        • 2011-08-01
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多