• \ 转义符
  • ^ 匹配输入字符串的开始位置
  • $ 匹配输入字符串的结束位置
  • * 匹配前面的子表达式任意次 。 zo*等价于zo{0,}
  • + 匹配前面的子表达式一次或多次。 zo+等价于zo{1,}
  • ? 匹配前面的子表达式零次或一次。zo?等价于zo{0,1}
  • {n} 匹配确定的n次。o{2}等价于oo
  • {n,} 至少匹配n次。o{2,}表示2个o,或者大于2个o
  • {n,m} 匹配n次到m次。o{2,5}表示有2个到5个的o
  • ? 当该字符紧跟在任何一个其他限制符(*,+,?,{n},{n,},{n,m})后面时,尽可能少的匹配所搜索的字符串,例如,对于字符串”oooo”,”o+?”将匹配单个”o”
  • . 匹配除”\r\n”之外的任何单个字符,要匹配包括”\r\n”在内的任何字符,请使用像”[\s\S]”的模式。
  • x|y 匹配x或y “z|food”能匹配”z”或”food”或”zood”
  • [xyz] 匹配所包含的任意一个字符 例如,”[abc]”可以匹配”plain”中的”a”。
  • [^xyz] 匹配未包含的任意字符 例如,”[^abc]”可以匹配”plain”中的”plin”。
  • [a-z] 匹配指定范围内的任意字符
  • [^a-z] 匹配任何不在指定范围内的任意字符
  • \b 匹配一个单词边界 例如,”er\b”可以匹配”never”中的”er”,但不能匹配”verb”中的”er”。
  • \B 匹配非单词边界。”er\B”能匹配”verb”中的”er”,但不能匹配”never”中的”er”。
  • \cx 匹配由x指明的控制字符。例如,\cM匹配一个Control-M或回车符。x的值必须为A-Z或a-z之一。否则,将c视为一个原义的“c”字符。
  • \d 匹配一个数字字符。等价于[0-9]。
  • \D 匹配一个非数字字符。等价于[^0-9]。
  • \f 匹配一个换页符。等价于\x0c和\cL。
  • \n 匹配一个换行符。等价于\x0a和\cJ。
  • \r 匹配一个回车符。等价于\x0d和\cM。
  • \s 匹配任何不可见字符,包括空格、制表符、换页符等等。等价于[ \f\n\r\t\v]。
  • \S 匹配任何可见字符。等价于[^ \f\n\r\t\v]。
  • \t 匹配一个制表符。等价于\x09和\cI。
  • \v 匹配一个垂直制表符。等价于\x0b和\cK。
  • \w 匹配包括下划线的任何单词字符。这里的”单词”字符使用Unicode字符集。
  • \W 匹配任何非单词字符。等价于“[^A-Za-z0-9_]”。
  • \< \ > 匹配词(word)的开始(\<)和结束(\ >)。例如正则表达式\< the\ >能够匹配字符串”for the wise”中的”the”,但是不能匹配字符串”otherwise”中的”the”。注意:这个元字符不是所有的软件都支持的。
  • | 将两个匹配条件进行逻辑“或”(Or)运算。
  • (pattern) 匹配 pattern 并捕获该匹配的子表达式。可以使用 $0…$9 属性从结果”匹配”集合中检索捕获的匹配。若要匹配括号字符 ( ),请使用”\(“或者”\)”
  • (?:pattern) 执行正向预测先行搜索的子表达式,该表达式匹配处于匹配 pattern 的字符串的起始点的字符串。它是一个非捕获匹配,即不能捕获供以后使用的匹配。例如,”Windows (?=95|98|NT|2000)” 匹配”Windows 2000”中的”Windows”,但不匹配”Windows 3.1”中的”Windows”。预测先行不占用字符,即发生匹配后,下一匹配的搜索紧随上一匹配之后,而不是在组成预测先行的字符后。
  • (?!pattern) 执行反向预测先行搜索的子表达式,该表达式匹配不处于匹配 pattern 的字符串的起始点的搜索字符串。它是一个非捕获匹配,即不能捕获供以后使用的匹配。例如,”Windows (?!95|98|NT|2000)” 匹配”Windows 3.1”中的 “Windows”,但不匹配”Windows 2000”中的”Windows”。预测先行不占用字符,即发生匹配后,下一匹配的搜索紧随上一匹配之后,而不是在组成预测先行的字符后.
posted on 2017-04-15 22:32  2637282556  阅读(72)  评论(0编辑  收藏  举报