Qt中文显示乱码解决方法
一、Qt4中的解决方法
方法1:在程序开始时增加初始编码类型
#include < QTextCodec >
int main(int argc, char **argv)
{
....................
QTextCodec::setCodecForTr(QTextCodec::codecForName("UTF8"));
QTextCodec::setCodecForLocale(QTextCodec::codecForName("UTF8"));
QTextCodec::setCodecForCStrings(QTextCodec::codecForName("UTF8"));
..........................
}
Qt5中, 取消了QTextCodec::setCodecForTr()和QTextCodec::setCodecForCString()这两个函数,而且网上很多都是不推荐这种写法。
方法2:直接转换
加上#include <qtextcodec.h>
QTextCodec *codec = QTextCodec::codecForName("GBK");//修改这两行
w.setWindowTitle(codec->toUnicode("中文按钮"));
完整代码:
#include "helloqt.h" #include <QtWidgets/QApplication> #include <qlabel.h> #include <qtextcodec.h> int main(int argc, char *argv[]) { QApplication a(argc, argv); HelloQt w; QTextCodec *codec = QTextCodec::codecForName("GBK"); w.setWindowTitle(codec->toUnicode("中文按钮")); w.resize(300, 140); QLabel label("test",&w); label.setGeometry(100, 50, 160, 30); w.show(); return a.exec(); }
二、Qt5中的解决方法
方法1:先将对应的cpp文件用windows自带的记事本打开,另存为UTF-8格式,然后在代码中,遇到中文字符,使用QStringLiteral("中文")进行修饰。这种方式每次新建一个class就要切出去用记事本编辑一下实在麻烦,而且每个中文字符串都要用QStringLiteral来修饰,实在麻烦。
#include "helloqt.h" #include <QtWidgets/QApplication> #include <qlabel.h> int main(int argc, char *argv[]) { QApplication a(argc, argv); HelloQt w; w.setWindowTitle(QStringLiteral("中文按钮")); w.resize(300, 140); QLabel label("test",&w); label.setGeometry(100, 50, 160, 30); w.show(); return a.exec(); }
方法2:在头文件申明中加上
#pragma execution_character_set("utf-8")
方法3:直接转换
加上#include <qtextcodec.h>
QTextCodec *codec = QTextCodec::codecForName("GBK");//修改这两行
w.setWindowTitle(codec->toUnicode("中文按钮"));
2020/2/10勇哥补充一篇:
一、文件读写时的中文乱码问题
如果文件读取时,有中文导致的乱码,可以使用QTextStream类读写文件,并设置该类的setAutoDetectUnicode(true)函数,设置自动识别Unicode编码,这样就不会显示中文乱码了
二、输入输出的中文乱码问题
因为Qt Creator保存的文件使用的是UTF-8编码(是任何平台、任何语言都可以使用的跨平台的字符集),所以MSVC编译器虽然可以正常编译带BOM的UTF-8编码的源文件,但是生成的可执行文件的编码是Windows本地字符集,比如GB2312
也就是在可执行文件中,字符串是以GB2312编码的,而可执行程序执行到字符串输出语句时,对这个字符串却是以UTF-8解码,这样就会出现乱码
解决办法
方法一:强制MSVC编译器生成的可执行文件使用UTF-8编码。需要在每个使用到中文字符串的头文件和源程序文件的前部加入如下的语句
#if _MSC_VER >=1600
#pragma execution_character_set("utf-8")
#endif
方法二:使用QStringLiteral()宏封装字符串。该宏在编译时将参数生成字符串数据,并且存储在编译后文件的只读数据段中,程序运行时使用到此字符串时,只需读出此字符串数据即可。当使用QStringLiteral()宏对字符串封装之后,就不能再使用tr()函数翻译字符串
————————————————
版权声明:本文为CSDN博主「江南、董少」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_41453285/article/details/100016856

