基本语法

括号

  • [方括号] 内容
  • {花括号} 次数
  • (小括号) 分组返回值、提升优先级
  • \ 转义

内容

  • 匹配字母: [a-zA-Z]\W
  • 匹配数字: [0-9]\d
  • 匹配非数字:[^0-9]\D
  • 匹配空白: \s
  • 匹配非空白: \S
  • 任意字符: .

次数

  • {直接写数字}
  • *{0,1}
  • +{1,}
  • ?{0,1}
  • 懒惰匹配(尽量匹配少)
    • *?
    • +?
    • ??

位置

  • ^
  • $
  • \b 单词边界
  • \B 非单词边界

编组

  • 组的命名: (?<组名>XXXX)
  • 提取内容: $<组名>

常用表达式

  • 网页地址:<img[^>]+src=""(.+?.jpg)"".*?>
  • 网页标题: <title>(.*)?</title>

(网摘)
[1]d$    //匹配正整数
^-[1-9]d
$   //匹配负整数
^-?[1-9]d$   //匹配整数
[2]d
|0$  //匹配非负整数(正整数 + 0)
^-[1-9]d|0$   //匹配非正整数(负整数 + 0)
[3]d
.d|0.d[1-9]d$   //匹配正浮点数
^-([1-9]d
.d|0.d[1-9]d)$  //匹配负浮点数
^-?([1-9]d
.d|0.d[1-9]d|0?.0+|0)$  //匹配浮点数
[4]d
.d|0.d[1-9]d|0?.0+|0$   //匹配非负浮点数(正浮点数 + 0)
^(-([1-9]d
.d|0.d[1-9]d))|0?.0+|0$  //匹配非正浮点数(负浮点数 + 0)
评注:处理大量数据时有用,具体应用时注意修正
匹配特定字符串:
[5]+$  //匹配由26个英文字母组成的字符串
[6]+$  //匹配由26个英文字母的大写组成的字符串
[7]+$  //匹配由26个英文字母的小写组成的字符串
[8]+$  //匹配由数字和26个英文字母组成的字符串
^w+$  //匹配由数字、26个英文字母或者下划线组成的字符串
在使用RegularExpressionValidator验证控件时的验证功能及其验证表达式介绍如下:
只能输入数字:“[9]
$”
只能输入n位的数字:“^d{n}$”
只能输入至少n位数字:“^d{n,}$”
只能输入m-n位的数字:“^d{m,n}$”
只能输入零和非零开头的数字:“^(0|[1-9][0-9])$”
只能输入有两位小数的正实数:“[10]+(.[0-9]{2})?$”
只能输入有1-3位小数的正实数:“[11]+(.[0-9]{1,3})?$”
只能输入非零的正整数:“^+?[1-9][0-9]
$”
只能输入非零的负整数:“^-[1-9][0-9]$”
只能输入长度为3的字符:“^.{3}$”
只能输入由26个英文字母组成的字符串:“[12]+$”
只能输入由26个大写英文字母组成的字符串:“[13]+$”
只能输入由26个小写英文字母组成的字符串:“[14]+$”
只能输入由数字和26个英文字母组成的字符串:“[15]+$”
只能输入由数字、26个英文字母或者下划线组成的字符串:“^w+$”
验证用户密码:“[16]w{5,17}$”正确格式为:以字母开头,长度在6-18之间,
只能包含字符、数字和下划线。
验证是否含有%&'',;=?$"等字符:“[%&'',;=?$x22]+”
只能输入汉字:“[17],{0,}$”
验证Email地址:“^w+[-+.]w+)
@w+([-.]w+).w+([-.]w+)$”
验证InternetURL:“^http://([w-]+.)+[w-]+(/[w-./?%&=])?$”
验证电话号码:“^((d{3,4})|d{3,4}-)?d{7,8}$”
正确格式为:“XXXX-XXXXXXX”,“XXXX-XXXXXXXX”,“XXX-XXXXXXX”,“XXX-XXXXXXXX”,“XXXXXXX”,“XXXXXXXX”。
验证身份证号(15位或18位数字):“^d{15}|d{}18$”
验证一年的12个月:“^(0?[1-9]|1[0-2])$”正确格式为:“01”-“09”和“1”“12”
验证一个月的31天:“^((0?[1-9])|((1|2)[0-9])|30|31)$”
正确格式为:“01”“09”和“1”“31”。
匹配中文字符的正则表达式: [u4e00-u9fa5]
匹配双字节字符(包括汉字在内):[^x00-xff]
匹配空行的正则表达式:n[s| ]
r
匹配HTML标记的正则表达式:/<(.)>.|<(.) />/
匹配首尾空格的正则表达式:(^s
)|(s$)
匹配Email地址的正则表达式:w+([-+.]w+)
@w+([-.]w+).w+([-.]w+)
匹配网址URL的正则表达式:http://([w-]+.)+[w-]+(/[w- ./?%&=]*)?

代码实例

  • C#
    MatchCollection matches = Regex.Matches(内容, Pattern);
    if (matches.Count > 0)
    {
    foreach (Match item in matches)
    {
    foo = item.Groups[1].Value;
    ...
    }
    }

  • Qt
    。。。

一些网址:


收集整理
by tyw66@qq.com
2017


  1. 1-9 ↩︎

  2. 1-9 ↩︎

  3. 1-9 ↩︎

  4. 1-9 ↩︎

  5. A-Za-z ↩︎

  6. A-Z ↩︎

  7. a-z ↩︎

  8. A-Za-z0-9 ↩︎

  9. 0-9 ↩︎

  10. 0-9 ↩︎

  11. 0-9 ↩︎

  12. A-Za-z ↩︎

  13. A-Z ↩︎

  14. a-z ↩︎

  15. A-Za-z0-9 ↩︎

  16. a-zA-Z ↩︎

  17. u4e00-u9fa5 ↩︎

posted on 2017-08-31 23:53  tyw66  阅读(169)  评论(0编辑  收藏  举报