Qt 5.x, ODBC (dBase, dbf), Windows, encodings

Qt 5.x, ODBC (dBase, dbf), Windows, encodings

本文关键字:dbf Windows encodings dBase ODBC Qt      更新时间:2023-10-16

该数据库是Windows-1251代码页(1C 7.7,如果您需要了解)中的一组dbf文件。我如何得到一个UTF-8字符串作为结果?以某种方式设法仅在控制台中查看所需的文本,并且仅使用区域设置:IBM 866

代码示例:

QSqlDatabase db = QSqlDatabase::addDatabase("QODBC");
db.setDatabaseName("Driver={Microsoft dBASE Driver (*.dbf)};DriverID=277;Dbq=/path/to/database");
db.open(); // Ok
QSqlQuery query = QSqlQuery("select descr from SC84", db);
query.next(); // Ok
// "╩єчютэюх цхыхчю"
qDebug(query.value(0).toByteArray().data());
// if setup locale ...
QTextCodec::setCodecForLocale(QTextCodec::codecForName("IBM 866"));
// "Кузовное железо" (i was looking for this russian words!)
qDebug(query.value(0).toByteArray().data());
// "╩єчютэюх цхыхчю"
QMessageBox::information(this, "test as is", query.value(0).toString());
// "тХй╤Ф╤З╤О╤В╤Н╤О╤Е ╤Ж╤Е╤Л╤Е╤З╤О" — what was wrong?
QMessageBox::information(this, "test from DOS-866",
  QTextCodec::codecForName("IBM 866")->toUnicode(query.value(0).toByteArray().data()));

我知道在某个地方有一个隐式转换。但找不到解决办法!

PS问题结束。很难猜测将"cp1251"重新编码为"cp866"的原因。问题是忽略了ODBC DSN字符串中的连接设置。尝试解决选项"DataCodePage=ANSI"失败,该选项被丢弃。但是在注册表SOFTWAREMicrosoftJet4.0EnginesxBase下设置此值立即解决了问题…

在查询结果中将cp1251编码为cp866,乱码文本。设置DataCodePage=ANSI" DSN ODBC被忽略。所以您需要在注册表SOFTWAREMicrosoftJet4.0EnginesxBase中设置ANSI的值。