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



不幸的是,我有很多CSV文件是用iso-8859-2编码的(根据括号(。我想用PHP迭代这些文件并转换它们。

我找到了 https://csv.thephpleague.com/9.0/converter/charset/但我使用转换功能的方式对我来说是不确定的。

他们的示例代码

use LeagueCsvCharsetConverter;
$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循环中遍历本地保存的文件以自动执行该过程的正确方法是什么?

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

您不必使用库。PHP中有一个函数可以做这个图标

最新更新