字符集编码问题探索
最近又一次被這個(gè)問(wèn)題折騰的夠嗆,索性研究了一下,總結(jié)如下。
首先請(qǐng)參考文章《數(shù)據(jù)庫(kù)字符集和編碼轉(zhuǎn)換》了解基本概念。
應(yīng)用程序調(diào)用接口取到的字符串其實(shí)是按某種方式編碼的(這是廢話),以GBK編碼為例。
如果調(diào)用的接口返回的是char*,那么可以直接顯示和打印。注意:D5C5,C8FD分別為“張”和“三”的GBK內(nèi)碼。如圖:
在這種情況下,QT使用toUnicode(GBK)或者fromLocal8Bit都可以還原字符串。
如果調(diào)用了Qt的數(shù)據(jù)庫(kù)驅(qū)動(dòng),則返回值類型是QVariant。Qt的數(shù)據(jù)庫(kù)驅(qū)動(dòng)默認(rèn)會(huì)將字符集設(shè)置為UTF-8。在我的例子中,由于取到的編碼為GBK,所以我修改了QT的驅(qū)動(dòng),不進(jìn)行UTF-8轉(zhuǎn)化。所以QVariant中存的直接是GBK內(nèi)碼。如圖:
QVariant和QString中直接存了GBK內(nèi)碼,當(dāng)然無(wú)法直接顯示。需要通過(guò)16進(jìn)制轉(zhuǎn)換(方法1)或者char轉(zhuǎn)換(方法2),重新組織成QString才能正常顯示。
附件:GBK編碼查看器
總結(jié)
- 上一篇: 太原战役简介抗日战争中国两军首次联手抗日
- 下一篇: PostgreSQL的QT驱动编译