解决QT读Visual Fox Pro DBF中文乱码问题

开发环境

  • 操作系统: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 
//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:\Program Files\Microsoft SDKs\Windows\v7.1\Include;%INCLUDE% 
set LIB=C:\Program Files\Microsoft SDKs\Windows\v7.1\Lib;%LIB%

set path=C:\Program Files (x86)\Microsoft Visual Studio 10.0\VC\bin;%path% 
set INCLUDE=C:\Program Files (x86)\Microsoft Visual Studio 10.0\VC\include;%INCLUDE% 
set LIB=C:\Program Files (x86)\Microsoft Visual Studio 10.0\VC\lib;%LIB%

set path=C:\Qt\Qt5.5.1\5.5\msvc2010\bin;%path% 
set INCLUDE=C:\Qt\Qt5.5.1\5.5\msvc2010\include;%INCLUDE% 
set LIB=C:\Qt\Qt5.5.1\5.5\msvc2010\lib;%LIB%

set path=C:\Program Files (x86)\Microsoft Visual Studio 10.0\Common7\IDE;%path%

cd C:\Qt\Qt5.5.1\5.5\Src\qtbase\src\plugins\sqldrivers\odbc

qmake odbc.pro

nmake

3、替换默认odbc驱动,自行备份

打开cmd,运行:

copy /Y C:\Qt\Qt5.5.1\5.5\Src\qtbase\plugins\sqldrivers\qsqlodbcd.dll C:\Qt\Qt5.5.1\5.5\msvc2010\plugins\sqldrivers\qsqlodbcd.dll
copy /Y C:\Qt\Qt5.5.1\5.5\Src\qtbase\plugins\sqldrivers\qsqlodbc.dll C:\Qt\Qt5.5.1\5.5\msvc2010\plugins\sqldrivers\qsqlodbc.dll
copy /Y C:\Qt\Qt5.5.1\5.5\Src\qtbase\plugins\sqldrivers\qsqlodbcd.lib C:\Qt\Qt5.5.1\5.5\msvc2010\plugins\sqldrivers\qsqlodbcd.lib
copy /Y C:\Qt\Qt5.5.1\5.5\Src\qtbase\plugins\sqldrivers\qsqlodbc.lib C:\Qt\Qt5.5.1\5.5\msvc2010\plugins\sqldrivers\qsqlodbc.lib
pause

直接下载:http://download.csdn.net/download/xinzhengs/10145841

方案二、使用QDbf

QDbf没有对中文支持,需要修改源代码。

qdbftable.h

enum Codepage {
        CodepageNotSet = 0,
        IBM437,
        IBM850,
        IBM866,
        Windows1250,
        Windows1251,
        Windows1252,
        GB18030, // 这里为增加代码
        UnsupportedCodepage
    };

qdbftable.cpp

static const uchar CODEPAGE_WINDOWS_ANSI_LATIN_1 = 0x03;
static const uchar CODEPAGE_GB18030 = 0x7A; // 这里为增加代码

//bool QDbfTablePrivate::setCodepage(QDbfTable::Codepage codepage)中switch (codepage)的default前增加:
case QDbfTable::GB18030:
    byte = CODEPAGE_GB18030;
    break;

//void QDbfTablePrivate::setTextCodec()中switch (m_codepage)的default前增加:
case QDbfTable::GB18030:
    m_textCodec = QTextCodec::codecForName("GB18030");
    break;

//bool QDbfTable::open(OpenMode openMode)中switch (codepage)的default前增加:
case CODEPAGE_GB18030:
    d->m_codepage = QDbfTable::GB18030;
    break;

你可能感兴趣的:(解决QT读Visual Fox Pro DBF中文乱码问题)