QString 问题

arg() 函数

QString的arg()函数可以自动替换掉QString中出现的占位符。
其占位符以 % 开始,后面是占位符的位置,例如 %1,%2 这种。

QString("[%1, %2]").arg(x).arg(y);

去除空白字符

头文件:

#include <QString>
QString QString::simplified () const

函数描述:
返回一个字符串,该字符串已从开始和结束处删除空白,并将内部包括ASCII字符’\t’,’\n’,’\v’,’\f’,’\r’和’ '.替换为‘ ’,如果替换后有两个空格的话,只保留一个空格。

QString QString::trimmed() const

函数描述:
返回值为去除了 开头和结尾 的空白字符串,这里的空白指QChar::isSpace()返回值为true,比如'\t','\n','\v','\f','\r'和' ';

QString 转 Char *

  1. Qstring先转为string,在转为char* (不会出现中文乱码)
Qstring fileName = "E://QT/game_type/1.txt";
std::string str = fileName.toStdString();
str.c_str()
  1. 借助QByteArray类
    头文件:
#include <QByteArray>
// 处理含有中文的字符串
Qstring  str;
char*  ch;
QByteArray ba = str.toUtf8();    
ch=ba.data();
或者       ch = str.toUtf8().data();

// 处理英文/ASII码,中文可能会出现乱码
Qstring  str;
char*  ch =  str.toLatin1().data();

char * 转 QString

  1. 利用QSstring的构造函数
char str[] = "frtyguhijk";
Qstring ss;
ss = Qstring(str);

或者
QString ss(str);

中文乱码问题:

ss.toUtf8().data()
  1. 用QString的静态转换函数获取,如fromUtf8()、fromLocal8bit()、fromUtf16()
char str[] = "frtyguhijk";
Qstring ss = QString::fromUtf8(str);

判断QString是否为空

isEmpty

 QString().isEmpty();            // returns true
 QString("").isEmpty();          // returns true
 QString("x").isEmpty();         // returns false
 QString("abc").isEmpty();       // returns false

isNull

 QString().isNull();             // returns true
 QString("").isNull();           // returns false
 QString("abc").isNull();        // returns false

两个QString的比较

QString :: compare()静态方法用于比较两个字符串。

QString::compare(QString , QString ,Qt::CaseInsensitive); 

Qt::CaseSensitivity 为枚举类型, 可取值Qt::CaseSensitive 和 Qt::CaseInsensitive, 表示匹配的灵敏度。

该方法返回一个整数。

  • 如果返回值小于零,则第一个字符串小于第二个字符串。
  • 如果它返回零,两个字符串都是相等的。
  • 如果返回值大于零,则第一个字符串大于第二个字符串。
QString1.compare(QString2)

QString::compare(QString1, QString2)

QString 与 数字 的转换

把QString转换为 double类型

QString str="123.45";
double val=str.toDouble(); // val=123.45

科学计数法形式转换

bool ok;
double d;
d=QString("1234.56e-02").toDouble(&ok);  
//ok=true;d = 12.3456.

把QString 转换为 float形

QString str="123.45";
float d=str.toFloat(); // d=123.45

常整形 转换为Qstring形

long a =63;
QString str=QString::number(a,16);  // str="3f";
str=QString::number(a,16);          // str="63";

字符串 section

返回字符串的一部分

    QString section(QChar sep, int start, int end = -1, SectionFlags flags = SectionDefault) const;
    QString section(const QString &in_sep, int start, int end = -1, SectionFlags flags = SectionDefault) const;

    QString section(const QRegExp &reg, int start, int end = -1, SectionFlags flags = SectionDefault) const;

    QString section(const QRegularExpression &re, int start, int end = -1, SectionFlags flags = SectionDefault) const;

该字符串被视为由字符sep分隔的字段序列。返回的字符串包含从位置开始到位置结束的所有字段。

如果未指定end,则包含从位置start到字符串结束的所有字段。

字段的编号为0、1、2等,从左开始计数,以及-1、-2等,从右到左计数。

flags参数可以用来影响函数的某些方面的行为,

例如是否区分大小写,是否跳过空字段,以及如何处理开头和结尾分隔符;看到SectionFlags。

SectionFlag 取值 作用
SectionDefault 0x00 计算空字段,不包括前导和结尾分隔符,并且区分大小写地比较分隔符
SectionSkipEmpty 0x01 将空字段视为不存在,即在start和end方面不考虑它们
SectionIncludeLeadingSep 0x02 在结果字符串中包含 前导分隔符(如果有的话)
SectionIncludeTrailingSep 0x04 在结果字符串中包含 结尾分隔符(如果有的话)
SectionCaseInsensitiveSeps 0x08 不区分大小写地比较分隔符

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容