字符串分割QString::section

section用来获取分割字符串,有多个重载版本。

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

参数1是分割符,取从参数2开始到参数3结束,参数3未指定则一直取到最后,参数4是分割选项。

#define debug qDebug()<<
int main(int argc, char *argv[])
{
    QString csv = "AA,BB,CC,DD,EE";
    debug csv.section(',', 2, 2);
    debug csv.section(',', 2, 3);
    debug csv.section(',', 2);
}

参数4字符串分割选项:

  • QString::SectionDefault 计算空字符串,不包括前导和尾随分隔符,并区分大小写

#define debug qDebug()<<
int main(int argc, char *argv[])
{
    QString str = "AA,,,BB,CC,DD,EE";
    debug str.section(',', 0,3,QString::SectionDefault);
    debug str.section(',', 1,1,QString::SectionDefault);
}

这里第1个分割的串是个空串,SectionDefault不包含前导和尾随分隔符那就直接是个空串。

  • QString::SectionSkipEmpty 忽略空字符串,不包括前导和尾随分割符。
#define debug qDebug()<<
int main(int argc, char *argv[])
{
    QString str = "AA,,,BB,CC,DD,EE";
    debug str.section(',', 0,3,QString::SectionSkipEmpty);
    debug str.section(',', 0,0,QString::SectionSkipEmpty);
    debug str.section(',', 1,1,QString::SectionSkipEmpty);
}

不论哪种分割选项取多个子串的时候中间的分割符还是会包含的。

  • QString::SectionIncludeLeadingSep 在结果字符串中包含前导分割符(如果有前导分割符)。
#define debug qDebug()<<
int main(int argc, char *argv[])
{
    QString str = "AA,,,BB,CC,DD,EE";
    debug str.section(',', 0,3,QString::SectionIncludeLeadingSep );
    debug str.section(',', 0,0,QString::SectionIncludeLeadingSep );
    debug str.section(',', 1,1,QString::SectionIncludeLeadingSep );
    debug str.section(',', 4,4,QString::SectionIncludeLeadingSep );
}

当子串前面有分隔符的时候会包含分割符的。

  • QString::SectionIncludeTrailingSep 在结果字符串中包含尾随分割符(如果有尾随分割符)。
#define debug qDebug()<<
int main(int argc, char *argv[])
{
    QString str = "AA,,,BB,CC,DD,EE";
    debug str.section(',', 0,3,QString::SectionIncludeTrailingSep );
    debug str.section(',', 0,0,QString::SectionIncludeTrailingSep );
    debug str.section(',', 1,1,QString::SectionIncludeTrailingSep );
    debug str.section(',', 4,4,QString::SectionIncludeTrailingSep );
}

  • QString::SectionCaseInsensitiveSeps 不区分大小写(不含分割符)。
#define debug qDebug()<<
int main(int argc, char *argv[])
{
    QString str = "WABACaDaEA";
    debug str.section('A', 0,3,QString::SectionCaseInsensitiveSeps );
    debug str.section('a', 0,3,QString::SectionCaseInsensitiveSeps );
    debug str.section('a', 0,0,QString::SectionCaseInsensitiveSeps );
    debug str.section('a', 1,1,QString::SectionCaseInsensitiveSeps );
    debug str.section('a', 4,4,QString::SectionCaseInsensitiveSeps );
}

字母a(A)将字符串分成几部分,如图当取多个子串的时候输出自动转了大小写。

其他重载版本:

QString QString::section(const QString &sep, int start, int end = -1, QString::SectionFlags flags = SectionDefault) const
QString QString::section(const QRegExp &reg, int start, int end = -1, QString::SectionFlags flags = SectionDefault) const 用符合正则表达式的子串作为分割符
QString QString::section(const QRegularExpression &re, int start, int end = -1, QString::SectionFlags flags = SectionDefault) const

  • 5
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
QString::number是一个静态成员函数,用于将数字转换为QString类型。它接受一个数字和一个可选的参数,将数字转换为QString类型并返回。 函数原型为: ```cpp QString QString::number(int n, int base = 10); QString QString::number(uint n, int base = 10); QString QString::number(long n, int base = 10); QString QString::number(ulong n, int base = 10); QString QString::number(long long n, int base = 10); QString QString::number(ulonglong n, int base = 10); QString QString::number(float n, char format = 'g', int precision = 6); QString QString::number(double n, char format = 'g', int precision = 6); ``` 参数n表示要转换的数字,base表示数字的进制,默认为十进制。当使用整型或无符号整型时,base可以设置为2、8、10或16,表示二进制、八进制、十进制或十六进制。 当使用浮点数时,可以使用format参数指定数字的格式,可以是'e'、'E'、'f'、'F'、'g'或'G',分别表示科学计数法、定点小数表示、自动选择科学计数法或定点小数表示,以及对应的大写形式。 precision参数表示小数点后的位数,仅对浮点数有效。 例如,以下代码将数字123转换为字符串并输出: ```cpp int n = 123; QString str = QString::number(n); qDebug() << str; // 输出"123" ``` 又如,以下代码将浮点数3.1415926转换为字符串并输出: ```cpp double d = 3.1415926; QString str = QString::number(d, 'f', 2); qDebug() << str; // 输出"3.14" ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值