Qt 正则匹配

比如QString str = “123你好456你好”我们要从这个str中提取出“123456”
QString str= “123你好456你好”;
QString tmp;
        for(int j = 0; j < str.length(); j++)
        {
            if(this->str[j] > '0' && this->str[j] < '9')
                this->tmp.append(this->str[j]);
        }
这样tmp中存放的就是“123456”。

在使用Qt Creator编程时,难免会用到将float类型转换为QString类型的时候下面是我所有的方法:

1. 将QString类型转化为float类型,很简单

    QString data;                 float num = data.toFloat();

    即可很轻松的实现。

2. 但是如何将float类型转化为QString类型呢?

    查看API很难发现封装好的转化函数

    可以尝试使用下面的代码转化:

    float num = 1.222;

    QString data = QString("float is %1").arg(num);

    输出结果是:float is 1.222

    如果只要float转化成的数值,则使用如下:

    QString data = QString("%1").arg(num);

保留小数点后两位

double/float  size = 2.3334524;

QString str = QString::number(size, 'f', 2);

其中f代表非科学计数法格式,2代表小数点后两位。

听说用正则表达式QRegExp也可实现。

"^\d+$"  //非负整数(正整数 + 0)  "^[0-9]*[1-9][0-9]*$"  //正整数  "^((-\d+)|(0+))$"  //非正整数(负整数 + 0)  "^-[0-9]*[1-9][0-9]*$"  //负整数  "^-?\d+$"    //整数  "^\d+(\.\d+)?$"  //非负浮点数(正浮点数 + 0)  "^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$"  //正浮点数  "^((-\d+(\.\d+)?)|(0+(\.0+)?))$"  //非正浮点数(负浮点数 + 0)  "^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$"  //负浮点数  "^(-?\d+)(\.\d+)?$"  //浮点数  "^[A-Za-z]+$"  //由26个英文字母组成的字符串  "^[A-Z]+$"  //由26个英文字母的大写组成的字符串  "^[a-z]+$"  //由26个英文字母的小写组成的字符串  "^[A-Za-z0-9]+$"  //由数字和26个英文字母组成的字符串  "^\w+$"  //由数字、26个英文字母或者下划线组成的字符串  "^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$"    //email地址  "^[a-zA-z]+://(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$"  //url  "^(d{2}|d{4})-((0([1-9]{1}))|(1[1|2]))-(([0-2]([1-9]{1}))|(3[0|1]))$" // 年-月-日  "^((0([1-9]{1}))|(1[1|2]))/(([0-2]([1-9]{1}))|(3[0|1]))/(d{2}|d{4})$" // 月/日/年  "^([w-.]+)@(([[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.)|(([w-]+.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(]?)$"   //Email  "(d+-)?(d{4}-?d{7}|d{3}-?d{8}|^d{7,8})(-d+)?"     //电话号码  "^(d{1,2}|1dd|2[0-4]d|25[0-5]).(d{1,2}|1dd|2[0-4]d|25[0-5]).(d{1,2}|1dd|2[0-4]d|25[0-5]).(d{1,2}|1dd|2[0-4]d|25[0-5])$"   //IP地址
^([0-9A-F]{2})(-[0-9A-F]{2}){5}$   //MAC地址的正则表达式  ^[-+]?\d+(\.\d+)?$ //值类型正则表达式
QRegExp是Qt的正则表达式类. Qt中有两个不同类的正则表达式. 第一类为元字符.它表示一个或多个常量表达式. 令一类为 转义字符,它代表一个特殊字符. 一.元字符 . 匹配任意单个字符.例如, 1.3 可能是1. 后面跟任意字符,再跟3 ^ 匹配字符串首. 例如, ^12可能是123,但不能是312 $ 配字符串尾. 例如, 12$可以是312, 当不能是 123 [] 匹配括号内输入的任意字符.[123]可以为1, 2 或3 * 匹配任意数量的前导字符. 例如, 1*2可以为任意数量个1(甚至没有), 后面跟一个2 + 匹配至少一个前导字符. 例如, 1+2必须为一个或多个1, 后跟一个2 ? 匹配一个前导字符或为空. 例如 1?2可以为2或这12 二.统配模式 通过 QRegExp::setPatternSyntax(QRegExp::Wildcard);可以将元字符设置为统配模式.在统配模式下,只有3个元字 符可以使用.他们的功能没有变化. ? 匹配任意单个字符, 例如, 1?2可以为1,后面跟任意单个字符, 再跟2 * 匹配任意一个字符序列. 例如, 1*2, 可以为1, 后面跟任意数量的字符, 再跟一个2 [] 匹配一个定义的字符集合. 例如, [a-zA-Z\.]可以匹配 a到z之间任意一个字符和. [^a]匹配出小写a以外的字符. 三.转义序列 \. 匹配"." \^ 匹配"^" \$ 匹配"$" \[ 匹配"[" \] 匹配"]" \* 匹配"*" \+ 匹配"+" \? 匹配"?" \b 匹配响铃字符,使计算机发出嘟的一声. \t 制表符号 \n 换行符号 \r 回车符鉿 \s 任意空格 \xnn 匹配16进制为nn的字符 \0nn 匹配8进制的nn字符 这些表达式均以\开始, 与C++的转义字符相同,所以为了定义QRegExp中的一个转义序列, 需要在前面添加两个\\
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值