簡體   English   中英

自動將 CSV 從 iso-8859-2 轉換為 utf-8

[英]Automating CSV conversion from iso-8859-2 to utf-8

我有很多 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 中有一個函數可以做那個iconv

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

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM