标签 正则 下的文章

正则表达式-思维导图

  • 语法结构
  • 字符
    • 普通字符:字母、数字、汉字、下划线,匹配与之相同的一个字符
    • 简单转义字符:\n(换行),\t(制表),\\(\本身)和 \^…(\^等有特殊作用的符号如要匹配自己的话要用转义)
    • 标准字符集合
      注意区分大小写,大写是相反的意思,匹配相反是不匹配

      • \d
        任意一个数字,0~9
      • \w
        任意一个字母、数字、汉字或下划线,A~Z、a~z、0~9、_和任意一个汉字
      • \s
        任意空白符,包括空格、制表符、换行符
      • .
        小数点可以匹配任意一个字符,换行除外(如果要匹配包括”\n”在内的所有字符,一般用[\s\S])
    • 自定义字符集合
      [ ]方括号匹配方式,能够匹配方括号中的任意一个字符,^表示取反

      • [ab5@]
        匹配”a”或”b”或”5″或”@”
      • [^abc]
        匹配a、b、c之外的任意字符
      • [f-k]
        匹配“f”到”k”之间的字符
      • [^A-F0-3]
        匹配“A”-“F”,”0″-“3″之外的任意一个字符
  • 量词(Quantifier)
    修饰前面的一个表达式,如果要修饰多个表达式,就用( )把表达式包起来

    • {n}
      表达式重复n次​
    • {m,n}
      表达式至少重复m次,最多重复n次

      • 贪婪模式 (默认)
        匹配符合的最长的字符串
      • 非贪婪模式 (在量词后面加 ? 例:{m,n}? )
        匹配符合的最短的字符串
    • {m,}
      表达式至少重复m次

    • 匹配表达式0或1次,相当于{0,1}
    • +
      表达式至少出现一次,相当于{1,}
    • *
      表达式不出现或出现任意次,相当于{0,}
  • 字符边界
    零宽:匹配的不是字符而是位置,符合某种条件的位置

    • ^
      与字符串开始的地方匹配
    • $
      与字符串结束的地方匹配
    • \b
      匹配一个单词的边界,当前位置前面的字符和后面的字符不全是\w
  • 预搜索(零宽断言、环视)
    零宽:匹配的不是字符而是位置,符合某种条件的位置

    • (?=exp)
      断言自身出现的位置的后面能匹配表达式exp
    • (?!exp)
      断言自身出现的位置的后面不能匹配表达式exp
    • (?<=exp)
      断言自身出现的位置的前面能匹配表达式exp
    • (?<!exp)
      断言自身出现的位置的前面不能匹配表达式exp
  • 匹配模式
    对文本的处理方式

    • IGNORECASE 忽略大小写模式
      • 匹配时忽略大小写
      • 默认是区分大小写的
    • SINGLELINE 单行模式
      • 整个文本看作一个字符串,只有一个开头一个结尾
      • 使小数点”.”可以匹配包含换行符(\n)在内的任意字符
    • MULTILINE 多行模式
      • 每行都是一个字符串
      • 在多行模式下,如果需要仅匹配字符串开始和结束位置,可以使用\A和\Z
  • 选择符和分组
    分支结构、捕获组合非捕获组

    • | 分支结构​
      左右表达式之间“或”关系,匹配左边或右边
    • ( ) 捕获组
      • (1)、在被修饰匹配次数的时候,括号中的表达式可以作为整体被修饰
      • (2)、取匹配结果的时候,括号中的表达式匹配到的内容可以被单独得到
      • (3)、每一对括号会分配一个编号,使用()的捕获根据左括号的顺序从1开始自动编号。捕获编号为零的第一个捕获是整个正则表达式模式匹配的文本
      • 反向引用:通过反向引用,可以对分组已捕获的字符串进行引用。
    • (?:Expression) 非捕获组
      一些表达式中,不得不使用(),但又不需要保存()中子表达式匹配的内容,这时可以用非捕获组来抵消()带来的副作用。\

原文链接

php126个常用的正则表达式

基于php常用正则表达式的整理汇总
1        /\w+([-+.’]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/  电子邮件
2        “^\d+$”  //非负整数(正整数 + 0)
3        “^[0-9]*[1-9][0-9]*$”  //正整数
4        “^((-\d+)|(0+))$”  //非正整数(负整数 + 0)
5        “^-[0-9]*[1-9][0-9]*$”  //负整数
6        “^-?\d+$”    //整数
7        “^\d+(\.\d+)?$”  //非负浮点数(正浮点数 + 0)
8        “^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$”  //正浮点数
9        “^((-\d+(\.\d+)?)|(0+(\.0+)?))$”  //非正浮点数(负浮点数 + 0)
10        “^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$”  //负浮点数
11        “^(-?\d+)(\.\d+)?$”  //浮点数
12        “^[A-Za-z]+$”  //由26个英文字母组成的字符串
13        “^[A-Z]+$”  //由26个英文字母的大写组成的字符串
14        “^[a-z]+$”  //由26个英文字母的小写组成的字符串
15        “^[A-Za-z0-9]+$”  //由数字和26个英文字母组成的字符串
16        “^\w+$”  //由数字、26个英文字母或者下划线组成的字符串
17        “^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$”    //email地址
18        “^[a-zA-z]+://(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$”  //url
19        /^(d{2}|d{4})-((0([1-9]{1}))|(1[1|2]))-(([0-2]([1-9]{1}))|(3[0|1]))$/   //  年-月-日
20        /^((0([1-9]{1}))|(1[1|2]))/(([0-2]([1-9]{1}))|(3[0|1]))/(d{2}|d{4})$/   // 月/日/年
21        “^([w-.]+)@(([[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.)|(([w-]+.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(]?)$”   //Emil
22        /^((\+?[0-9]{2,4}\-[0-9]{3,4}\-)|([0-9]{3,4}\-))?([0-9]{7,8})(\-[0-9]+)?$/     //电话号码
23        “^(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地址
24        匹配中文字符的正则表达式: [\u4e00-\u9fa5]
25        匹配双字节字符(包括汉字在内):[^\x00-\xff]
26        匹配空行的正则表达式:\n[\s| ]*\r
27        匹配HTML标记的正则表达式:/<(.*)>.*<\ 1=””>|<(.*)>/
28        匹配首尾空格的正则表达式:(^\s*)|(\s*$)
29        匹配Email地址的正则表达式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
30        匹配网址URL的正则表达式:^[a-zA-z]+://(\\w+(-\\w+)*)(\\.(\\w+(-\\w+)*))*(\\?\\S*)?$
31        匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
32        匹配国内电话号码:(\d{3}-|\d{4}-)?(\d{8}|\d{7})?
33        匹配腾讯QQ号:^[1-9]*[1-9][0-9]*$
34        元字符及其在正则表达式上下文中的行为:
35        \ 将下一个字符标记为一个特殊字符、或一个原义字符、或一个后向引用、或一个八进制转义符。
36        ^ 匹配输入字符串的开始位置。如果设置了 RegExp 对象的Multiline 属性,^ 也匹配 ’\n’ 或 ’\r’ 之后的位置。
37        $ 匹配输入字符串的结束位置。如果设置了 RegExp 对象的Multiline 属性,$ 也匹配 ’\n’ 或 ’\r’ 之前的位置。
38        * 匹配前面的子表达式零次或多次。
39        + 匹配前面的子表达式一次或多次。+ 等价于 {1,}。
40        ? 匹配前面的子表达式零次或一次。? 等价于 {0,1}。
41        {n} n 是一个非负整数,匹配确定的n 次。
42        {n,} n 是一个非负整数,至少匹配n 次。
43        {n,m} m 和 n 均为非负整数,其中n <= m。最少匹配 n 次且最多匹配 m 次。在逗号和两个数之间不能有空格。
44        ? 当该字符紧跟在任何一个其他限制符 (*, +, ?, {n}, {n,}, {n,m}) 后面时,匹配模式是非贪婪的。非贪婪模式尽可能少的匹配所搜索的字符串,而默认的贪婪模式则尽可能多的匹配所搜索的字符串。
45        . 匹配除 “\n” 之外的任何单个字符。要匹配包括 ’\n’ 在内的任何字符,请使用象 ’[.\n]’ 的模式。
46        (pattern) 匹配pattern 并获取这一匹配。
47        (?:pattern) 匹配pattern 但不获取匹配结果,也就是说这是一个非获取匹配,不进行存储供以后使用。
48        (?=pattern) 正向预查,在任何匹配 pattern 的字符串开始处匹配查找字符串。这是一个非获取匹配,也就是说,该匹配不需要获取供以后使用。
49        (?!pattern) 负向预查,与(?=pattern)作用相反
50        x|y 匹配 x 或 y。
51        [xyz] 字符集合。
52        [^xyz] 负值字符集合。
53        [a-z] 字符范围,匹配指定范围内的任意字符。
54        [^a-z] 负值字符范围,匹配任何不在指定范围内的任意字符。
55        \b 匹配一个单词边界,也就是指单词和空格间的位置。
56        \B 匹配非单词边界。
57        \cx 匹配由x指明的控制字符。
58        \d 匹配一个数字字符。等价于 [0-9]。
59        \D 匹配一个非数字字符。等价于 [^0-9]。
60        \f 匹配一个换页符。等价于 \x0c 和 \cL。

61        \n 匹配一个换行符。等价于 \x0a 和 \cJ。
62        \r 匹配一个回车符。等价于 \x0d 和 \cM。
63        \s 匹配任何空白字符,包括空格、制表符、换页符等等。等价于[ \f\n\r\t\v]。
64        \S 匹配任何非空白字符。等价于 [^ \f\n\r\t\v]。
65        \t 匹配一个制表符。等价于 \x09 和 \cI。
66        \v 匹配一个垂直制表符。等价于 \x0b 和 \cK。
67        \w 匹配包括下划线的任何单词字符。等价于’[A-Za-z0-9_]’。
68        \W 匹配任何非单词字符。等价于 ’[^A-Za-z0-9_]’。
69        \xn 匹配 n,其中 n 为十六进制转义值。十六进制转义值必须为确定的两个数字长。
70        \num 匹配 num,其中num是一个正整数。对所获取的匹配的引用。
71        \n 标识一个八进制转义值或一个后向引用。如果 \n 之前至少 n 个获取的子表达式,则 n 为后向引用。否则,如果 n 为八进制数字 (0-7),则 n 为一个八进制转义值。
72        \nm 标识一个八进制转义值或一个后向引用。如果 \nm 之前至少有is preceded by at least nm 个获取得子表达式,则 nm 为后向引用。如果 \nm 之前至少有 n 个获取,则 n 为一个后跟文字 m 的后向引用。如果前面的条件都不满足,若 n 和 m 均为八进制数字 (0-7),则 \nm 将匹配八进制转义值 nm。
73        \nml 如果 n 为八进制数字 (0-3),且 m 和 l 均为八进制数字 (0-7),则匹配八进制转义值 nml。
74        \un 匹配 n,其中 n 是一个用四个十六进制数字表示的Unicode字符。
75        匹配中文字符的正则表达式: [u4e00-u9fa5]
76        匹配双字节字符(包括汉字在内):[^x00-xff]
77        匹配空行的正则表达式:n[s| ]*r
78        匹配HTML标记的正则表达式:/<(.*)>.*|<(.*)>/
79        匹配首尾空格的正则表达式:(^s*)|(s*$)
80        匹配Email地址的正则表达式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*
81        匹配网址URL的正则表达式:http://([w-]+.)+[w-]+(/[w- ./?%&=]*)?
82        利用正则表达式限制网页表单里的文本框输入内容:
83        用正则表达式限制只能输入中文:
onkeyup=”value=value.replace(/[^u4E00-u9FA5]/g,”)”
84        用正则表达式限制只能输入全角字符:
onkeyup=”value=value.replace(/[^uFF00-uFFFF]/g,”)”
85        用正则表达式限制只能输入数字:
onkeyup=”value=value.replace(/[^d]/g,”) “onbeforepaste=”clipboardData.setData(‘text’,clipboardData.getData(‘text’).replace(/[^d]/g,”))”
86        用正则表达式限制只能输入数字和英文:
onkeyup=”value=value.replace(/[W]/g,”) “onbeforepaste=”clipboardData.setData(‘text’,clipboardData.getData(‘text’).replace(/[^d]/g,”))”
87        =========常用正则式
88        匹配中文字符的正则表达式: [\u4e00-\u9fa5]
89        匹配双字节字符(包括汉字在内):[^\x00-\xff]
90        匹配空行的正则表达式:\n[\s| ]*\r
91        匹配HTML标记的正则表达式:/<(.*)>.*<\ 1=””>|<(.*)>/
92        匹配首尾空格的正则表达式:(^\s*)|(\s*$)
93        匹配IP地址的正则表达式:/(\d+)\.(\d+)\.(\d+)\.(\d+)/g //
94        匹配Email地址的正则表达式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
95        匹配网址URL的正则表达式:http://(/[\w-]+\.)+[\w-]+(/[\w- ./?%&=]*)?
96        sql语句:^(select|drop|delete|create|update|insert).*$
97        非负整数:^\d+$
98        正整数:^[0-9]*[1-9][0-9]*$
99        非正整数:^((-\d+)|(0+))$
100        负整数:^-[0-9]*[1-9][0-9]*$
101        整数:^-?\d+$
102        非负浮点数:^\d+(\.\d+)?$
103        正浮点数:^((0-9)+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$
104        非正浮点数:^((-\d+\.\d+)?)|(0+(\.0+)?))$
105        负浮点数:^(-((正浮点数正则式)))$
106        英文字符串:^[A-Za-z]+$
107        英文大写串:^[A-Z]+$
108        英文小写串:^[a-z]+$
109        英文字符数字串:^[A-Za-z0-9]+$
110        英数字加下划线串:^\w+$
111        E-mail地址:^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$
112        URL:^[a-zA-Z]+://(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\s*)?$
113        ^http:\/\/[A-Za-z0-9]+\.[A-Za-z0-9]+[\/=\?%\-&_~`@[\]\’:+!]*([^<>\”\”])*$
114        邮政编码:^[1-9]\d{5}$
115        中文:^[\u0391-\uFFE5]+$
116        电话号码:^((\(\d{2,3}\))|(\d{3}\-))?(\(0\d{2,3}\)|0\d{2,3}-)?[1-9]\d{6,7}(\-\d{1,4})?$
117        手机号码:^((\(\d{2,3}\))|(\d{3}\-))?13\d{9}$
118        双字节字符(包括汉字在内):^\x00-\xff
119        匹配首尾空格:(^\s*)|(\s*$)(像vbscript那样的trim函数)
120        匹配HTML标记:<(.*)>.*<\ 1=””>|<(.*)>
121        匹配空行:\n[\s| ]*\r
122        提取信息中的网络链接:(h|H)(r|R)(e|E)(f|F) *= *(‘|”)?(\w|\\|\/|\.)+(‘|”| *|>)?
123        提取信息中的邮件地址:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
124        提取信息中的图片链接:(s|S)(r|R)(c|C) *= *(‘|”)?(\w|\\|\/|\.)+(‘|”| *|>)?
125        提取信息中的IP地址:(\d+)\.(\d+)\.(\d+)\.(\d+)
126        提取信息中的中国手机号码:(86)*0*13\d{9}

学习正则技巧

1、^ 和 $ ,分别用来匹配字符串的开始和结束,举例说明如下:

“^abc$”:就是要求以abc开头和以abc结尾的字符串,实际上是只有abc匹配;

2、‘*’ ‘+’ 和 ‘?’他们用来表示一个字符可以出现的次数或者顺序,他们分别表示:

“zero or more”相当于{0,},“ab*”:和ab{0,}同义,匹配以a开头,后面可以接0个或者N个b组成的字符串(”a”, “ab”, “abbb”, 等);
“one or more”相当于{1,},“ab+”:和ab{1,}同义,同上条一样,但最少要有一个b存在 (”ab” “abbb”等);
“zero or one.”相当于{0,1},“ab?”:和ab{0,1}同义,可以没有或者只有一个b;
“a?b+$”:匹配以一个或者0个a再加上一个以上的b结尾的字符串。

要点:’*’ ‘+’ 和 ‘?’ 只管它前面那个字符。

3、大括号{}

“ab{2}”: 要求a后面一定要跟两个b(一个也不能少)(”abb”);
“ab{2,}”: 要求a后面一定要有两个或者两个以上b(如”abb” “abbbb” 等);
“ab{3,5}”: 要求a后面可以有2-5个b(”abbb”, “abbbb”, or “abbbbb”)。    看了上面的例子,你对{n,m}应该理解了吧。要注意的是,n和m都不能为负整数,而且n总是小于m。这样,才能最少匹配n次且最多匹配m次,如”p{1,5}”将匹配 “pvpppppp”中的前五个p。

4、小括号()
( )    合并整体匹配,并放入内存,可使用\1 \2…依次获取;
“a(bc)*”: 匹配 a 后面跟0个或者一个”bc”;
“a(bc){1,5}”: 一个到5个 “bc”;

5、字符 ‘|’,相当于OR操作

“hi|hello”: 匹配含有”hi” 或者 “hello” 的字符串;
“(b|cd)ef”: 匹配含有 “bef” 或者 “cdef”的字符串;
“(a|b)*c”: 匹配含有这样多个(包括0个)a或b,后面跟一个c的字符串;

6、一个点’.’

可以代表所有的单一字符,不包括”\n”
如果,要匹配包括”\n”在内的所有单个字符,怎么办?用’[\n.]’这种模式。
“a.[0-9]”: 一个a加一个字符再加一个0到9的数字;
“^.{3}$”: 三个任意字符结尾。

7、中括号括住的内容只匹配一个单一的字符

“[ab]”: 匹配单个的 a 或者 b ( 和 “a│b” 一样);
“[a-d]”: 匹配’a’ 到’d’的单个字符 (和”a│b│c│d” 还有 “[abcd]”效果一样);
一般我们都用[a-zA-Z]来指定字符为一个大小写英文:
“^[a-zA-Z]”: 匹配以大小写字母开头的字符串;
“[0-9]%”: 匹配含有形如 x% 的字符串;
“,[a-zA-Z0-9]$”: 匹配以逗号再加一个数字或字母结尾的字符串;

你也可以把你不想要得字符列在中括号里,你只需要在总括号里面使用 ’^’作为开头
“%[^a-zA-Z]%”:匹配含有两个百分号里面有一个非字母的字符串。

要点:^用在中括号开头的时候,就表示排除括号里的字符。
为了PHP能够解释,你必须在这些字符面前后加双引号,并且将一些字符转义。
在中括号里面,所有的特殊字符,包括(”),都将失去他们的特殊性质,“[*\+?{}.]”匹配含有这些字符的字符串。

8、以\开头的

\b     出现在目标字符串的开头或结尾的两个边界之一,边界可以是空格或者特殊字符;比如’ve\b’,可以匹配love里的ve而不匹配very里有ve。
\B     对象必须位于目标字符串的开头和结尾两个边界之内,即匹配对象既不能作为目标字符串的开头,也不能作为目标字符串的结尾;
\s:   用于匹配单个空格符,包括tab键和换行符,等价于[\f\t\v];
\S:   用于匹配除单个空格符之外的任何一个字符,[^\f\t\v];
\d:   匹配从0到9的一个数字,等价于[0-9];
\D     匹配除数字以外任何一个字符,等价于[^0-9];
\w:   用于匹配一个字母、数字或下划线字符,等价于[0-9a-zA-Z_];
\W:   用于匹配所有除英文字母、数字和下划线以外任何的一个字符,[^0-9a-zA-Z_];
\A     匹配字符串串首的原子
\Z     匹配字符串串尾的原子
\f     匹配一个换页符等价于 \x0c 或 \cL
匹配一个换行符;等价于 \x0a 或 \cJ
匹配一个回车符等价于\x0d 或 \cM
\t     匹配一个制表符;等价于 \x09\或\cl
\v     匹配一个垂直制表符;等价于\x0b或\ck
\oNN   匹配一个八进制数字
\xNN   匹配一个十六进制数字
\cC    匹配一个控制字符

9、指定某一个范围而不局限于具体的字符

/[A-Z]/
上述正则表达式将会与从A到Z范围内任何一个大写字母相匹配。
/[a-z]/
上述正则表达式将会与从a到z范围内任何一个小写字母相匹配。
/[0-9]/
上述正则表达式将会与从0到9范围内任何一个数字相匹配。
/([a-z][A-Z][0-9])+/

———————————–手把手教你如何撰写正则表达式————————————-

经典正则表达式应用1:如何构建一个模式来匹配货币数量的输入。

构建一个匹配模式去检查输入的信息是否为一个表示money的数字。
我们认为一个表示money的数量有四种方式:“10000.00”和“10,000.00”,或者没有小数部分,“10000”and“10,000”。
现在让我们开始构建这个匹配模式:

^[1-9][0-9]*$
这是所变量必须以非0的数字开头,但这也意味着单一的”0″也不能通过测试,以下是解决的方法:
^(0|[1-9][0-9]*)$
“只有0和不以0开头的数字与之匹配”,我们也可以允许一个负号在数字之前:
^(0|-?[1-9][0-9]*)$
这就是:0或者一个以0开头且可能有一个负号在前面的数字。
好了,现在让我们别那么严谨,允许以0开头。现在让我们放弃负号,因为我们在表示钱币的时候并不需要用到。我们现在指定模式用来匹配小数部分:
^[0-9]+(\.[0-9]+)?$
这暗示匹配的字符串必须最少以一个阿拉伯数字开头。但是注意,在上面模式中“10.”是不匹配的, 只有“10”和“10.2”才可以,你知道为什么吗?
^[0-9]+(\.[0-9]{2})?$
我们上面指定小数点后面必须有两位小数。如果你认为这样太苛刻,你可以改成:
^[0-9]+(\.[0-9]{1,2})?$
这将允许小数点后面有一到两个字符。现在我们加上用来增加可读性的逗号(每隔三位),我们可以这样表示:
^[0-9]{1,3}(,[0-9]{3})*(\.[0-9]{1,2})?$

不要忘记’+’可以被’*’替代如果你想允许空白字符串被输入话,也不要忘记反斜杆’\’在php字符串中可能会出现错误 (很普遍的错误)。

经典正则表达式应用2:构造检查email的正则表达式
在一个完整的email地址中有三个部分:
1. 用户名 (在‘@’左边的一切) 2.’@’,3. 服务器名
用户名可以含有大小写字母阿拉伯数字,句号(’.’)减号(’-’)and下划线’_’),服务器名字也是符合这个规则,当然下划线除外。
现在,用户名的开始和结束都不能是句点,服务器也是这样,还有你不能有两个连续的句点他们之间至少存在一个字符。
好现在我们来看一下怎么为用户名写一个匹配模式:

^[_a-zA-Z0-9-]+$
现在还不能允许句号的存在,我们把它加上:
^[_a-zA-Z0-9-]+(\.[_a-zA-Z0-9-]+)*$
上面的意思就是说:以至少一个规范字符(除了.)开头,后面跟着0个或者多个以点开始的字符串。
简单化一点,我们可以用eregi()取代ereg(),eregi()对大小写不敏感, 我们就不需要指定两个范围“a-z”和“A-Z”只需要指定一个就可以了:
^[_a-z0-9-]+(\.[_a-z0-9-]+)*$
后面的服务器名字也是一样,但要去掉下划线:
^[a-z0-9-]+(\.[a-z0-9-]+)*$
好,现在只需要用”@”把两部分连接:
^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*$
这就是完整的email认证匹配模式了,只需要调用:
eregi(”^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*$”,$eamil)

就可以得到是否为email了

——————————-正则表达式的其他用法———————————–

提取字符串

ereg() and eregi() 有一个特性是允许用户通过正则表达式去提取字符串的一部分。
比如说,我们想从 path/URL 提取文件名,下面的代码就是你需要:

ereg(”([^\\/]*)$”, $pathOrUrl, $regs);
echo $regs[1];

高级的代换

ereg_replace() 和 eregi_replace()也是非常有用的,假如我们想把所有的间隔负号都替换成逗号:
ereg_replace(”[ \n\r\t]+”, “,”, trim($str));

人生的悲剧只有两种:一种是没有得到自己想要的东西,另一种是得到自己想要的东西。
                                —王尔德

标签

打赏