天天看点

QString,const char*,char* string 互转的问题综合解决,含有中文路径的解决方案

主要是写给自己看的,每次都会出现中文字乱码的现象。

今天终于找到了解决方法,我在网上看到了这样的一段解释,源自于QT Center,是这样的:

rajeshs ask a question:

How can I convert a QString to char* and vice versa ?

Answer:

      In order to convert a QString to a char*, then you first need to get a latin1 representation of the string by calling toLatin1() on it which will return a QByteArray. Then call data() on the QByteArray to get a pointer to the data stored in the byte array. See the documentation:  

int main(int argc, char **argv)

{

 QApplication app(argc, argv);

 QString str1 = “Test”;

 QByteArray ba = str1.toLatin1();

 const char *c_str2 = ba.data();

 printf(“str2: %s”, c_str2);

 return app.exec();   

}

Note that it is necessary to store the bytearray before you call data() on it, a call like the following

               const char *c_str2 = str2.toLatin1().data();

will make the application crash as the QByteArray has not been stored and hence no longer exists.

To convert a char* to a QString you can use the QString constructor that takes a QLatin1String, e.g:

QString string = QString(QLatin1String(c_str2)) ;

上面代码中的加粗蓝色句子是关键,好多人都知道QString 转 const char*要经过两步:

(1)先通过toLatin1()或toAscii()方法转为QByteArray();

(2)再通过data()或constData()方法

就转换成了const  char *。

    但是,好多人都这样写的代码:

     QString str;

     const char *s = str.toLatin1().data();

或  const char *s =  str.toAscii().data();

这样的话,str.toLatin1()的内容没有存储,就直接调用了data()方法。因此,结果就为空或者乱码。

正确的写法应该是这样的:

———————————————————————-

       QString  str;

       QByteArray   aByteArray  =  str.toLatin1();//先把转化为QByteArray的结果存储起来

       const char *s =  aByteArray.data();//再调用data()或constData()

————————————————————————————

或者:

       QString  str;

       QByteArray   aByteArray  =  str.toAscii();//先把转化为QByteArray的结果存储起来

       const char *s =  aByteArray.data();//再调用data()或constData()

——————————————————————————————————————–

Append:

     今天找到了一个更好的解决方法:

  QString  str;

const char *temStr = str.toLocal8Bit();//(1)

qDebug()<<temStr;//(2)

这样,(2)处打印出来也是乱码,但是,可以这样直接把str.toLocal8Bit()放到你要用到const char *的地方,就可以了,我试了,能正常工作。

刚开始,看到qDebug出来的是乱码,以为不能用,后来发现不影响正常使用。

<div id="article_content" class="article_content clearfix csdn-tracking-statistics" data-pid="blog" data-mod="popu_307" data-dsm="post">
                <div class="markdown_views">
            <p>整合网络上的解决方法 <br>
           

解决方法一

1. string转const char*

string s = "abc";
   const char* c_s = s.c_str();           
  • 1
  • 2
  1. const char*转string

    直接赋值即可

    const char* c_s = “abc”;

    string s(c_s);

  2. string转char*

    string s = “abc”;

    char* c;

    const int len = s.length();

    c = new char[len+1];

    strcpy(c,s.c_str());

  3. char*转string

    char* c = “abc”;

    string s(c);

  4. const char*转char*

    const char* cpc = “abc”;

    char* pc = new char[100];//足够长

    strcpy(pc,cpc);

  5. char*转const char*

    直接赋值即可

    char* pc = “abc”;

    const char* cpc = pc;

解决方法二

1. const char* 和string 转换

(1) const char*转换为 string,直接赋值即可。

EX: const char* tmp = “tsinghua”.

string s = tmp;

(2) string转换为const char*,利用c_str()

EX: string s = “tsinghua”;

const char*tmp = s.c_str();

2. char*和const char*之间的转换

(1) const char*转化为char*,利用const_cast

Qstring str = "helloworld";
char *s;
QByteArray ba = str.toLatin1(); 
s = ba.data();           
  • 1
  • 2
  • 3
  • 4

这样就完成了 QString 向 char* 的转化。切记第三行 code 不可以省略。

  1. 将 char * 转化成 QString

Exp :

QString str; 

char *s  = "helloworld"; 

str = QString(QLatin1String(s));           
  • 1
  • 2
  • 3

std::string cstr;

QString qstring;

//从std::string 到QString

qstring = QString(QString::fromLocal8Bit(cstr.c_str()));

//从QString 到 std::string

cstr = string((const char *)qstring.toLocal8Bit());

//不需要从gbk转到utf8

QString value_content = QString::fromStdString(vec[i].content);

QString value_classname = QString::fromStdString(vec[i].classname);