开发环境
- 操作系统:Win10 x64
- QT:5.5.1 x86
- 编译器:Microsoft Windows SDK for Windows 7 x64
方案一、使用ODBC读取DBF
前提
- QT安装时选择源代码:Source Components-Essentials
- 安装VFP驱动:Visual FoxPro ODBC Driver v6.01.8629.01
1、代码修改
打开C:\Qt\Qt5.5.1\5.5\Src\qtbase\src\sql\drivers\odbc\qsql_odbc.cpp,可以看到在qGetStringData方法中,非unicode数据读取的时候是按utf-8读取的,中文dbf是以gbk编码存储的,gbk编码转成utf-8时如果没有对应字符则以”?”代替,这种转换是有损!这也就是为什么QSqlQuery::value()方法读到的数据无论如何转码也无法正常显示了。为了解决这个问题,代码做如下修改:
#include <QTextCodec>
//fieldVal += QString::fromUtf8((const char *)buf.constData(), rSize);
fieldVal += QTextCodec::codecForName("GB18030")->toUnicode((const char *)buf.constData(), rSize);
2、代码编译
打开cmd,运行:
set path=C:\Program Files\Microsoft SDKs\Windows\v7.1\Bin;%path%
set INCLUDE=C: