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 *
- Qstring先转为string,在转为char* (不会出现中文乱码)
Qstring fileName = "E://QT/game_type/1.txt";
std::string str = fileName.toStdString();
str.c_str()
- 借助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
- 利用QSstring的构造函数
char str[] = "frtyguhijk";
Qstring ss;
ss = Qstring(str);
或者
QString ss(str);
中文乱码问题:
ss.toUtf8().data()
- 用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 ®, 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 | 不区分大小写地比较分隔符 |