什么是正则表达式?浅谈 c++中的正则表达式

截取作者c++部分 原文地址

什么是正则表达式?

正则表达式(Regular Expression)就是用某种模式去匹配一类字符串的公式。如你要在一篇文章中查找第一个字是“李”最后一个字是“明”的三个字的姓名,即“李*明”;那么“李*明”就是公式,也称作模式(Pattern),这篇文章就是要匹配的串(或叫文本text)。再如,你要检查输入的一个字符串是否是126邮箱的格式,你得制定一个规则去查检,这种规则就是正则表达式。

我们就从上面提到的一个例子开始:检查一个字符串是否符合126邮箱的格式。

我们从网易的邮箱注册页面可以看到126邮箱的用户名需要符合以下的格式:6~18个字符,可使用字母、数字、下划线,需以字母开头我们可以定义一个模式:^[a-zA-Z]\w{5,17}@126.com

 

这个模式可以这样理解:

[a-zA-Z]:任何一个azAZ的英文字母

^:      表示以什么开头,则^[a-zA-Z]表示以字母开头

\w:     单词字符[a-zA-Z_0-9],即a-zA-Z0-9_中的任何一个字符

{5,17}:  表示出现517(至少5次,不超过17),则\w{5,17}表示5~17个字符。

                因为还有一个以非数字字母开头的字符,所以^[a-zA-Z]\w{5,17}表示:“6~18个字符,可使用字母、数字、下划线,需以字母开头

@126.com表示符合以上规则的用户名后跟上@126.com字符串,即组成一个邮箱地址。

^[a-zA-Z]\w{5,17}@126.com ”就是我们所说的正则表达式。

正则表达式常用符号

上面一个示例中用到的“^”、“\w”、“{5,17}”等都是正则表达式中的常用符号,这些符号在正则表达式中都有特殊的含意。下面这个表格是Java中的正则表达式常用符号的含意(只抽取了其常用的部分进行说明,就这些部分其实可以解决关于正则表达式的绝大多数的问题了)

模式

匹配的内容(含意)

 

 

字符类

[abc]

a、b 或 c(简单类)

[^abc]

任何字符,除了 a、b 或 c(否定)

[a-zA-Z]

a 到 z 或 A 到 Z,两头的字母包括在内(范围)

[a-d[m-p]]

a 到 d 或 m 到 p:[a-dm-p](并集)

[a-z&&[def]]

d、e 或 f(交集)

[a-z&&[^bc]]

a 到 z,除了 b 和 c:[ad-z](减去)

[a-z&&[^m-p]]

a 到 z,而非 m 到 p:[a-lq-z](减去)

 

 

预定义字符类

.

任何字符(与行结束符可能匹配也可能不匹配)

\d

数字:[0-9]

\D

非数字: [^0-9]

\s

空白字符:[ \t\n\x0B\f\r]

\S

非空白字符:[^\s]

\w

单词字符:[a-zA-Z_0-9]

\W

非单词字符:[^\w]

 

 

边界匹配器

^

行的开头

$

行的结尾

\b

单词边界

\B

非单词边界

\A

输入的开头

\G

上一个匹配的结尾

\Z

输入的结尾,仅用于最后的结束符(如果有的话)

\z

输入的结尾

 

 

数量词(Greedy策略)

X?

X,一次或一次也没有

X*

X,零次或多次

X+

X,一次或多次

X{n}

X,恰好 n 次

X{n,}

X,至少 n 次

X{n,m}

X,至少 n 次,但是不超过 m 次

 

 

逻辑运算符

XY

X 后跟 Y

X|Y

X 或 Y

(X)

X,作为捕获组

参考文档:Class Pattern

这些常用的符号在各种编程语言的正则表达式中含意基本相同(因为正则表达式的思想是相同的),所以都可以用来参数。但不同的语言可能会有一些细小的差别,如果要针对各种编程语言,想有更精确和权威的说明,可参考其官方文档:

C++(VS2013编译器)http://msdn.microsoft.com/zh-cn/library/bb982727.aspx#grammarsummary

正则表达式的使用

下面从常见的需求出发讲述C++JavaJavaScript中正则表达式的使用

C++中的正则表达式

C++中正则表达式主要有三种实现方式:C语言的实现方式(C regex)C++标准库的实现(C++ regex)Boost库的实现(boost regex)C regex的方式是一种面向过程的编程方式,使用起来不太方便;C++ regex的方式因为是标准库的一部分,所以可以直接使用(好像Linux平台下不支持),但C++ regex非常难用,语法要求比较严格,而且好多默认的选项和我们正常的想法不一样;Boost是一个开源的第三方库,这个库非常优秀,广泛应用于C++的项目开发中,boost regex非常灵活好用,C++开发时是大家推崇的一种方式。

关于boost regex的用法,在后继的文章将会进一步介绍,现在以C++ regex的方式列举一个使用样例。

1.验证ip地址

  1. #include <regex>  
  2. #include <iostream>  
  3. #include <string>  
  4.   
  5. bool IsIpV4Address(const std::string& strIp)  
  6. {  
  7.     //验证IP地址的模式,这里"\."中的"\"是转义字符,表示这是一个.  
  8.     const std::regex pattern("(\\d{1,3}){1}\.(\\d{1,3}){1}\.(\\d{1,3}){1}\.(\\d{1,3}){1}");  
  9.     //匹配验证  
  10.     return std::regex_match(strIp, pattern);  
  11. }  
  12.   
  13. int main()  
  14. {  
  15.     std::string strIp1 = "134.34.34.4";//192.168.1.1  
  16.     std::string strIp2 = "192.168.255";  
  17.   
  18.     std::cout << strIp1 << " : " << (IsIpV4Address(strIp1) ? "valid" : "invalid") << std::endl;  
  19.     std::cout << strIp2 << " : " << (IsIpV4Address(strIp2) ? "valid" : "invalid") << std::endl;  
  20.     return 0;  
  21. }  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值