C++使用正则表达式

来源:互联网 发布:mastercam数控车编程 编辑:程序博客网 时间:2024/06/06 00:34

概述

正则表达式 , 又称规则表达式 , 英文名为 Regular Expression , 在代码中常简写为 regex , regexp 或 RE , 是计算机科学的一个概念 ; 正则表通常被用来检索 , 替换那些符合某个模式 (规则) 的文本 ;

正则表达式是对字符串 (包括普通字符 , 例如 : a 到 z 之间的字母) 和特殊字符 (称为 “元字符” ) 操作的一种逻辑公式 , 就是用事先定义好的一些特定字符 , 及这些特定字符的组合 , 组成一个 “规则字符串” , 这个 “规则字符串” 用来表达对字符串的一种过滤逻辑 ; 正则表达式是一种文本模式 , 模式描述在搜索文本时要匹配的一个或多个字符串 ;

C++对正则表达式的支持

C++ 原生支持正则表达式 , 只需导入相关都文件即可 , 如下 :

#include <regex>using namespace std;

代码中运用实例如下 :

// 定义一个正则表达式 , 4~23 位数字和字母的组合regex repPattern("[0-9a-zA-Z]{4,23}",regex_constants::extended);// 声明匹配结果变量match_results<string::const_iterator> rerResult;// 定义待匹配的字符串string strValue = "123abc";// 进行匹配bool bValid = regex_match(strValue, rerResult, repPattern);if (bValid){    // 匹配成功}

常用的正则表达式

校验数字的表达式

数字 : ^[0-9]*$n 位的数字 : ^\d{n}$至少 n 位的数字 : ^\d{n,}$m-n 位的数字 : ^\d{m,n}$零和非零开头的数字 : ^(0|[1-9][0-9]*)$非零开头的最多带两位小数的数字 : ^([1-9][0-9]*)+(.[0-9]{1,2})?$带 1~2 位小数的正数或负数 : ^(\-)?\d+(\.\d{1,2})?$正数 , 负数 , 和小数 : ^(\-|\+)?\d+(\.\d+)?$有两位小数的正实数 : ^[0-9]+(.[0-9]{2})?$有 1~3 位小数的正实数 : ^[0-9]+(.[0-9]{1,3})?$非零的正整数 : ^[1-9]\d*$ 或 ^([1-9][0-9]*){1,3}$ 或 ^\+?[1-9][0-9]*$非零的负整数 : ^\-[1-9][]0-9″*$ 或 ^-[1-9]\d*$非负整数 : ^\d+$ 或 ^[1-9]\d*|0$非正整数 : ^-[1-9]\d*|0$ 或 ^((-\d+)|(0+))$非负浮点数 : ^\d+(\.\d+)?$ 或 ^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0$非正浮点数 : ^((-\d+(\.\d+)?)|(0+(\.0+)?))$ 或 ^(-([1-9]\d*\.\d*|0\.\d*[1-9]\d*))|0?\.0+|0$正浮点数 : ^[1-9]\d*\.\d*|0\.\d*[1-9]\d*$ 或 ^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$负浮点数 : ^-([1-9]\d*\.\d*|0\.\d*[1-9]\d*)$ 或 ^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$浮点数 : ^(-?\d+)(\.\d+)?$ 或 ^-?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0)$

校验字符的表达式

汉字 : ^[\u4e00-\u9fa5]{0,}$英文和数字 : ^[A-Za-z0-9]+$ 或 ^[A-Za-z0-9]{4,40}$长度为 3~20 的所有字符 : ^.{3,20}$由 26 个英文字母组成的字符串 : ^[A-Za-z]+$由 26 个大写英文字母组成的字符串 : ^[A-Z]+$由 26 个小写英文字母组成的字符串 : ^[a-z]+$由数字和 26 个英文字母组成的字符串 : ^[A-Za-z0-9]+$由数字 , 26 个英文字母或者下划线组成的字符串 : ^\w+$ 或 ^\w{3,20}$中文 , 英文 , 数字包括下划线 : ^[\u4E00-\u9FA5A-Za-z0-9_]+$中文 , 英文 , 数字但不包括下划线等符号 : ^[\u4E00-\u9FA5A-Za-z0-9]+$ 或 ^[\u4E00-\u9FA5A-Za-z0-9]{2,20}$可以输入含有^%&',;=?$\"等字符 : [^%&',;=?$\x22]+禁止输入含有 ~ 的字符 : [^~\x22]+

特殊需求表达式

Email 地址 : ^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$域名 : [a-zA-Z0-9][-a-zA-Z0-9]{0,62}(/.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+/.?InternetURL : [a-zA-z]+://[^\s]* 或 ^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$手机号码 : ^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\d{8}$电话号码("XXX-XXXXXXX" , "XXXX-XXXXXXXX" , "XXX-XXXXXXX" , "XXX-XXXXXXXX" , "XXXXXXX"和"XXXXXXXX) : ^($$\d{3,4}-)|\d{3.4}-)?\d{7,8}$国内电话号码 (0511-4405222 , 021-87888822) : \d{3}-\d{8}|\d{4}-\d{7}身份证号 (15 位 , 18 位数字) : ^\d{15}|\d{18}$短身份证号码 (数字 , 字母 x 结尾) : ^([0-9]){7,18}(x|X)?$ 或 ^\d{8,18}|[0-9x]{8,18}|[0-9X]{8,18}?$帐号是否合法(字母开头,允许 5~16 字节,允许字母数字下划线) : ^[a-zA-Z][a-zA-Z0-9_]{4,15}$密码 (以字母开头,长度在 6~18 之间,只能包含字母 , 数字和下划线) : ^[a-zA-Z]\w{5,17}$强密码 (必须包含大小写字母和数字的组合,不能使用特殊字符,长度在 8~10 之间) : ^(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,10}$日期格式 : ^\d{4}-\d{1,2}-\d{1,2}一年的 12 个月(01~09和1~12) : ^(0?[1-9]|1[0-2])$一个月的 31 天(01~09和1~31) : ^((0?[1-9])|((1|2)[0-9])|30|31)$

作者 Github : tojohnonly , 博客 : EnskDeCode

原创粉丝点击