首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >自动将CSV从iso-8859-2转换为utf-8

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

Stack Overflow用户
提问于 2020-01-16 17:21:46
回答 2查看 194关注 0票数 0

我有相当多的CSV文件不幸地编码为iso-8859-2 (根据括号)。我想用PHP遍历这些文件并转换它们。

我找到了https://csv.thephpleague.com/9.0/converter/charset/,但我不确定如何使用转换函数。

他们的示例代码

代码语言:javascript
复制
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);

到目前为止,这是我的代码,它是表单的一部分,用于上传一个文件并将内容保存到数据库以供测试。当然,它以不正确的格式保存文本。

代码语言:javascript
复制
$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循环中迭代本地保存的文件以自动执行该过程,正确的方法是什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-01-16 17:24:28

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

票数 1
EN

Stack Overflow用户

发布于 2020-01-17 20:08:30

我最终按照提示使用了iconv

代码语言:javascript
复制
$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);
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59766402

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档