MySQL导入含有中文字段(内容)CSV文件乱码解决方法

前两天做项目中用到含有中文字段的数据CSV文件,使用workbench导入文件报错:

方式一:导入的时候选择合适的字符集 10008

方式二:导入前,用记事本或者其他的软件将字体修改为utf-8


从网上找了很长时间都说是CSV文件编码与client编码不匹配的问题,尝试将CSV转化为utf8编码,导入还是不行。


最后使用Navicat工具完成导入:



Encoding特别重要,要选择10008(MAC-Simplified Chinese GB 2312)不能使用默认的utf-8,因为含有中文的CSV文件一般都是采用10008这种编码方式而不是utf8。

错误方式:



编码不对就会出现乱码现象!!!





至此,完成数据导入工作!




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果你的 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); ``` 希望以上方法可以帮助你解决中文码问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值