Qt中 int ,float ,double转换为QString 有两种方法 1.使用 QString::number(); 如:
- long a = 63;
- QString s = QString::number(a, 10);
- QString t = QString::number(a, 16).toUpper();
(解释,变量a为int型或者float,double。10和16为进制) toUpper是大写2.使用
- long a = 63;
- QString s = QString(”%1”).arg(a);
这个嘛,我不常用
把QString转换为 double类型 方法1.
- QString str=“123.45”;
- double val=str.toDouble();
方法2.很适合科学计数法形式转换
- bool ok;
- double d;
- d=QString(”1234.56e-02”).toDouble(&ok);
把QString转换为float形 1.
- QString str=“123.45”;
- float d=str.toFloat();
2.
- QString str=“R2D2”;
- bool ok;
- float d=str.toFloat(&ok); //转换是被时返回0.0,ok=false;
把QString形转换为整形 1.转换为十进制整形 注意:基数默认为10。当基数为10时,并且基数必须在2到36之 间。如果基数为0,若字符串是以0x开头的就会转换为16进制,若以0开头就转换为八进制,否则就转换为十进制。
- Qstring str=“FF”;
- bool ok;
- int dec=str.toInt(&ok,10);
- int hex =str.toInt(&ok,16);
3.常整形转换为Qstring形
- long a =63;
- QString str=QString::number(a,16);
- QString str=QString::number(a,16).toUpper();
Qstring 转换char*问题! 方法一:
- QString qstr(“hello,word”);
- const char * p = qstr.toLocal8Bit().data();
方法二:
- const char *p = qstr.toStdString().data();
转换过来的是常量
把当前时间转化为QString…public QDateTime qdate = QDateTime.currentDateTime(); datetime = qdate.toString(“yyyy年MM月dd日ddddhh:mm:ss”); 如果不是QTime和QDate类比如说:通过TCP/IP接收到的char unsigned char 类等如何转换为QString类 QString Time2String( DWORD dwTime) { char cTime[50] = {0}; memset(cTime,0,50); strftime(cTime,32,”%Y-%m-%d %H:%M:%S”,localtime(&time_t(dwTime))); return QString(cTime); }
由于我采用Qt来写的界面,所以用到了QString类型 1. QString和string的相互转换
-
-
-
- QString s2q(const string &s)
- {
- return QString(QString::fromLocal8Bit(s.c_str()));
- }
- string q2s(const QString &s)
- {
- return string((const char *)s.toLocal8Bit());
- }
//————————
- QString data;
- data.toLatin1().data();
- int char2num(char ch)
- {
- if(ch>=‘0’&&ch<=‘9’)return ch-‘0’;
- else if(ch>=‘a’&&ch<=‘f’)return ch-‘a’+10;
- return -1;
- }
- QString::number(number,10);//10表示的是进制,如是16进制,则改为16
- uint8_t Message_Digest;
- QString::number(Message_Digest,16);
6. BYTE* to char[] to QString
- QString textshow = NULL;
- BYTE * output = new BYTE[1024];
- for(int i=0; i<16; i++)
- {
- char pBuff[2];
- sprintf(pBuff,“%02x”,output[i]);
- textshow = textshow + pBuff;
- }
7. string to BYTE [] //其中#define unsigned char BYTE
-
-
-
- void CryptClient::HexStrToByte(string str_arr, BYTE byte_arr[24])
- {
- unsigned char ch1;
- unsigned char ch2;
- int k = 0;
- for (int i=0; i<str_arr.length()-1; i = i+2)
- {
- ch1 = str_arr.at(i);
- ch2 = str_arr.at(i+1);
- if (ch1>=48 && ch1 <= 57)
- {
- ch1 &= 0x0F;
- }
- if (ch1>=‘A’ && ch1 <=‘F’)
- {
- ch1 &= 0x0F;
- ch1 += 0x09;
- }
- if (ch2 >= 48 && ch2 <= 57)
- {
- ch2 &= 0x0F;
- }
- if (ch2>=‘A’ && ch2 <=‘F’)
- {
- ch2 &= 0x0F;
- ch2 += 0x09;
- }
- ch1<<=4;
- byte_arr[k] = ch1 + ch2;
- k++;
- }
- }
——————————————- 8. BYTE[] to string //上个过程的逆过程
-
-
-
- string* byteToHexStr(BYTE byte_arr[], int arr_len)
- {
- string* hexstr = new string;
- for(int i=0; i<arr_len; i++)
- {
- char hex1;
- char hex2;
- int value = byte_arr[i];
- int v1 = value/16;
- int v2 = value % 16;
-
- if (v1>=0 && v1<=9)
- {
- hex1 = (char)(48 + v1);
- }
- else
- {
- hex1 = (char)(55 + v1);
- }
-
- if (v2>=0 && v2<=9)
- {
- hex2 = (char)(48 + v2);
- }
- else
- {
- hex2 = (char)(55 + v2);
- }
-
- *hexstr = *hexstr + hex1 + hex2;
- }
- return hexstr;
- }
——————————————-
- QString keyall1;
- char keych1[MAX_NUM];
- keyall1 = QString(QLatin1String(keych1));
嗯,基本上程序中就用到了这么多,写出来,留着以后自己参考,要是有人能用到,那就更好啦~~~~~~~~ 转载:http://www.360doc.com/content/13/1010/15/12424571_320330123.shtml |