CSV文件导入数据库后中文乱码

CSV文件导入数据库后中文乱码
改编码前导入的数据
背景:我用的是Dbeaver连接的clickhouse数据库,向现场的同事要了数据(CSV格式文件),导入后都是途中这样的,根本用不了。在网上找到同样的情况的文章,记录一下,加深记忆(没技术含量,但是要总结经验)。
正文如下:
1、把CSV文件的后缀名改成 .txt。
2、双击打开文件,文件–》另存文件,在弹出框的最下面有编码选项,选择utf-8后保存。
在这里插入图片描述
3、把文件后缀名再改成 .csv。
4、这样就可以正常使用了,导入成功。
改编码后导入的数据

原文链接: https://blog.csdn.net/immocha/article/details/106396737.

  • 6
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
如果你的 CSV 文件中包含中文字符,而在导入到 Qt 中后出现了乱码问题,可能是因为你没有正确地设置文件编码。你可以尝试以下几种方法: 1. 在打开 CSV 文件时,使用 QTextCodec::codecForName() 函数指定正确的编码方式。例如: ``` QFile file("data.csv"); if (file.open(QIODevice::ReadOnly | QIODevice::Text)) { QTextStream in(&file); in.setCodec("UTF-8"); // 指定编码方式 while (!in.atEnd()) { QString line = in.readLine(); // 处理每行数据 } file.close(); } ``` 2. 如果你使用的是 QTableView 控件来展示数据,可以在设置数据模型时,指定模型的编码方式。例如: ``` QStandardItemModel *model = new QStandardItemModel(); model->setHorizontalHeaderLabels(headers); // 设置表头 model->setRowCount(rows); // 设置行数 model->setColumnCount(cols); // 设置列数 QFile file("data.csv"); if (file.open(QIODevice::ReadOnly | QIODevice::Text)) { QTextStream in(&file); in.setCodec("UTF-8"); // 指定编码方式 int row = 0; while (!in.atEnd()) { QString line = in.readLine(); QStringList fields = line.split(","); // 根据逗号分隔每个字段 for (int col = 0; col < cols; col++) { QStandardItem *item = new QStandardItem(fields[col]); model->setItem(row, col, item); } row++; } file.close(); } ui->tableView->setModel(model); // 设置数据模型 ``` 3. 如果你使用的是 QSqlTableModel 来操作数据库,可以在创建数据库连接时,指定连接的编码方式。例如: ``` QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL"); db.setHostName("localhost"); db.setDatabaseName("mydb"); db.setUserName("myuser"); db.setPassword("mypassword"); db.setPort(3306); db.setConnectOptions("MYSQL_OPT_RECONNECT=1"); db.setConnectOptions("MYSQL_OPT_CHARSET_NAME=utf8"); // 指定编码方式 if (!db.open()) { qDebug() << "Failed to connect to database"; return; } QSqlTableModel *model = new QSqlTableModel(); model->setTable("mytable"); model->setEditStrategy(QSqlTableModel::OnManualSubmit); model->select(); ui->tableView->setModel(model); ``` 希望以上方法可以帮助你解决中文乱码问题。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值