C_and_CPP 板


LINE

開發平台(Platform): (Ex: Win10, Linux, ...) win7 64bit 編譯器(Ex: GCC, clang, VC++...)+目標環境(跟開發平台不同的話需列出) qt 5.8.0 mingw 32bit xmapp 7.1.1 Apache/2.4.25 (Win32) OpenSSL/1.0.2j PHP/7.1.1 MariaDB 伺服器字元集: UTF-8 Unicode (utf8) 額外使用到的函數庫(Library Used): (Ex: OpenGL, ...) 問題(Question): 在phpMyadmin裡面中文顯示正常,欄位和資料庫的編碼都有設定為utf8_unicode_ci qt5 之後的預設應該都是utf-8編碼了,照理說應該不會有中文亂碼問題 但是query出來後的中文資料全部都亂碼 餵入的資料(Input): 預期的正確結果(Expected Output): Opened 工址 構造 Closing... 錯誤結果(Wrong Output): Opened "撌亙" "瑽\uF561\u0080" Closing... 程式碼(Code):(請善用置底文網頁, 記得排版) QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL"); db.setHostName("localhost"); db.setUserName("admin"); db.setPassword("0000"); db.setDatabaseName("test"); if(db.open()) { qDebug()<<"Opened"; QSqlQuery qry; if(qry.exec("SELECT `Col_Name` FROM `column_table` WHERE `Category_ID`=01 AND `Authority`=0")) { while(qry.next()) { qDebug()<< qry.value(0).toString().trimmed(); } } else { qDebug()<<"error: "<<qry.lastError().text(); } qDebug()<<"Closing..."; db.close(); } else { qDebug()<<"error: "<<db.lastError().text(); } 補充說明(Supplement): 有試過在前面加上 QTextCodec *codec = QTextCodec::codecForName("UTF-8"); QTextCodec::setCodecForLocale(codec); 但是出來的內容一樣是亂碼 Opened "撌亙?" "瑽鹉耿 Closing... 有測試過用sqlite3 資料庫內容一樣為中文 用qdebug輸出顯示是正常的中文 不知道到底哪個環節設定錯誤… 卡關好久 orz 有沒有人知道怎麼解? 補充 直接用qDebug()<< qry.value(0).toByteArray(); 顯示輸出 Opened "\xE6\x92\x8C\xE4\xBA\x99" "\xE7\x91\xBD\xEF\x95\xA1\xC2\x80" Closing... 若加上 QTextCodec *codec = QTextCodec::codecForName("UTF-8"); QTextCodec::setCodecForLocale(codec); 顯示輸出變成 Opened "\xE5\xB7\xA5\xE5\x9D\x80" "\xE6\xA7\x8B\xE9\x80\xA0" Closing... --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 36.233.182.226
※ 文章網址: https://webptt.com/m.aspx?n=bbs/C_and_CPP/M.1488387465.A.1A4.html
1F:→ uranusjr: 要不要試著把你拿到的 bytes 直接印出來?這超難除錯的 03/02 01:38
2F:→ ppi3106: 用bytearray 方式印出來嗎? 03/02 01:39
3F:→ uranusjr: 之類的, 反正就是繞過 encoding 直接看 binary 03/02 01:43
※ 編輯: ppi3106 (36.233.182.226), 03/02/2017 01:53:11
4F:→ ppi3106: 已補充 03/02 01:53
5F:→ ppi3106: 還麻煩幫忙看看,謝謝 03/02 02:24
6F:→ uranusjr: Hmm, 資料看起來是 UTF-8 沒錯, 所以問題在 Qt 轉字串時 03/02 02:57
7F:→ uranusjr: 用的編碼是錯的; 嘛簡單的解就是你手動 decode 就好... 03/02 02:57
但是因為用qry.value抓下來的時候,他function就預設是QString了 設了codec之後,直接印qry.value(0)顯示的會是如下 Opened QVariant(QString, "撌亙?") QVariant(QString, "瑽鹉耿) Closing... 所以其實懷疑是不是mysql的設置上哪裡出錯,但是編碼又都設為utf8了…
8F:→ uranusjr: (我說的是你有設 codec 的狀況) 03/02 02:59
9F:→ uranusjr: 問一下, 你是在程式的哪個階段設 codec? 03/02 03:00
10F:推 longlongint: 來個截圖呀 cmd要換code page 03/02 08:02
11F:→ ppi3106: 在main一開始進去的時候就設codec了?還是應該設在別處? 03/02 11:56
12F:→ ppi3106: 回long大,請問是要哪個畫面的截圖,用console輸出是測試 03/02 11:57
13F:→ ppi3106: 主要還是要丟到tableview裡面,因為會遇到一樣的亂碼問題 03/02 11:58
※ 編輯: ppi3106 (36.233.182.226), 03/02/2017 12:03:39
14F:推 RishYang: QString一個字是16bits 03/23 20:23
15F:→ RishYang: 然而Qt的判段多位元組序列有問題,首位元組的最高位為11 03/23 20:47
16F:→ RishYang: 10是三位元組序列 03/23 20:47
17F:→ RishYang: 可以試試把正確的QByteArray用QString::fromUtf8()轉成Q 03/23 20:55
18F:→ RishYang: String看看會不會正確 03/23 20:55
19F:→ RishYang: 剛剛搞錯了一些,Qt沒問題,而你已經寫對了,只要把正確 03/23 21:31
20F:→ RishYang: 的QByteArray轉回QString即可 03/23 21:31







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:BabyMother站內搜尋

TOP