QT5.12的QByteArray转QString中文出现乱码的问题

 扣扣技术交流群:460189483 

在做UDP通讯时,使用QByteArray接收到的数据,其中包括接收到的中文数据,在使用QString进行显示时,会出现乱码的问题,于是找了几种方法,走过的坑,都写下来,留作查看!

// QString转QByteArray方法,这个没问题

//Qt5。12
QString str("hello");  
QByteArray bytes = str.toUtf8(); // QString转QByteArray方法1 
 
QString str("hello");  
QByteArray bytes = str.toLatin1();  // QString转QByteArray方法2

//QByteArray转QString方法

方法一:如果只是字符串转换没有问题,有中文会出现乱码

    QByteArray bytes("hello world");
    QString string = bytes;   // QByteArray转QString方法1
 
    QByteArray bytes("hello world");
    QString string;
    string.prepend(bytes);// QByteArray转QString方法2
 
    qDebug() << string;

方法二:解决了QLabel显示乱码的问题,但是没有解决QByteArray有中文会出现乱码的问题

QByteArray nameArray = array.mid(PRO_DATA_POS,10)  //从array数组的pos开始,取10个字节
QString name = QString::fromLocal8Bit(nameArray);  //包含中文会出现乱码
QString name = QString(nameArray);                 //包含中文会出现乱码
QString name = QString::fromLocal8Bit(“机器人”);   //这样显示中文没问题,但是将机器人换成变量不行
QLabel *label = new QLabel();
label->setText(name);

解决方法:采样QTextCodec解码GBK编码方式解决 

#include <QTextCodec>

QByteArray nameArray = array.mid(PRO_DATA_POS,10)  //从array数组的pos开始,取10个字节
QTextCodec *codec = QTextCodec::codecForName("GBK");//指定QString的编码方式
QString name = codec->toUnicode(nameArray);//nameArray可以是char*,可以是QByteArray

QLabel *label = new QLabel();
label->setText(name);        //这样中文显示没问题

 

在Qt中,`QByteArray`是一个字节序列容器,而`QString`是Unicode字符串。要将`QByteArray`换成`QString`并显示为16进制形式,通常会先解码字节然后再换成十六进制。这里有一个简单示例: ```cpp #include <QDebug> #include <QByteArray> #include <QString> void QByteArrayToHexAndString(QByteArray bytes) { // 解码字节数组为UTF-8字符串 QString utf8String = QString::fromUtf8(bytes.data(), bytes.size()); // 换为16进制字符串 QByteArray hexBytes; for (const auto& byte : bytes) { hexBytes.append(QString("%1").arg(byte, 2, 16, '0')); } QString hexString = hexBytes.join(""); qDebug() << "Original String (Hex):" << hexString; } ``` 然后你可以调用这个函数,并传入需要处理的`QByteArray`。 如果你想要从16进制字符串还原为汉字,可以先解析出每个字符的Unicode编码,再换为对应的汉字。但在实际操作中,16进制到汉字的映射通常是通过特定的表(如ASCII字符集)或者是编码(比如GBK、GB2312等)来进行,这一步比较复杂,涉及到字符集的换。 举个例子,如果已知16进制值对应的是ASCII字符,可以这样做: ```cpp void HexToChinese(const QByteArray& hexStr) { const char* asciiTable = ...; // ASCII字符表或预定义的映射 for (int i = 0; i < hexStr.length(); i += 2) { uint16_t hexValue = QByteArray::number(hexStr[i] + hexStr[i+1], 16).toUShort(); if (hexValue <= 127 && asciiTable[hexValue]) { QString chineseChar = QLatin1Char(asciiTable[hexValue]); qDebug() << "Hex: " << hexStr.mid(i, 2) << " -> Chinese: " << chineseChar; } else { qDebug() << "Invalid character at position " << i << ": " << hexStr.mid(i, 2); } } } ``` 请注意,这只是一个简化示例,实际应用中你需要处理更多的边缘情况和非ASCII字符。同时,对于非ASCII字符,例如汉字,可能需要其他复杂的字符集换算法。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值