一般长这样
^[0-9]+abc$
使用:
var str = "123abc";
var patt1 = /^[0-9]+abc$/;
document.write(str.match(patt1));
^ 为匹配输入字符串的开始位置。
$ 为匹配输入字符串的结束位置。
一个字符串其实就是一个简单的正则表达式,例如 Hello World 正则表达式匹配 "Hello World" 字符串。
实例
a\s+
a后面可以匹配多个空格
\d+
匹配>=1个数字
()?
设置括号内的选项是可选的
\.
匹配“.”
^\d+(.\d+)?
可以匹配的实例:"5", "1.5" 和 "2.21"
.*
任何东西
*
>=0个
+
>=1个
?
0或者1个
注意
当?紧随(*、+、?、{n}、{n,}、{n,m})之后时
匹配模式是"非贪心的"(尽可能短的字符串)
"贪心的"模式(尽可能长的字符串)
例如,在字符串"oooo"中,"o+?"只匹配单个"o",而"o+"匹配所有"o"。
{n}
n 是非负整数。=n个
{n,}
n 是非负整数。n<= 个
{n,m}
M 和 n 是非负整数,其中 n <= m。n<=个数<=m
注意:不能将空格插入逗号和数字之间。
x|y
匹配x或者y
[xyz]
匹配包含的任一字符
例如,"[abc]"匹配"plain"中的"a"。
[^xyz]
匹配未包含的任何字符
例如,"[^abc]"匹配"plain"中"p","l","i","n"。
[a-z]
匹配a-z之间的内的任何字符
[^a-z]
匹配不在a-z的任何字符
\b
匹配一个字边界,即字与空格间的位置
例如,"er\b"匹配"never"中的"er",但不匹配"verb"中的"er"
\B
非字边界匹配
"er\B"匹配"verb"中的"er",但不匹配"never"中的"er"
\d
[0-9]
\D
不是[0-9]
\w
匹配任何字类字符,包括下划线。与"[A-Za-z0-9_]"等效
\W
上面取反
捕获组
public class RegexMatches
{
public static void main( String args[] ){
// 按指定模式在字符串查找
String line = "This order was placed for QT3000! OK?";
String pattern = "(\\D*)(\\d+)(.*)";
// 创建 Pattern 对象
Pattern r = Pattern.compile(pattern);
// 现在创建 matcher 对象
Matcher m = r.matcher(line);
if (m.find( )) {
System.out.println("Found value: " + m.group(0) );//整个表达式
System.out.println("Found value: " + m.group(1) );
System.out.println("Found value: " + m.group(2) );
System.out.println("Found value: " + m.group(3) );
} else {
System.out.println("NO MATCH");
}
}
}
得到的结果
Found value: This order was placed for QT3000! OK?
Found value: This order was placed for QT
Found value: 3000
Found value: ! OK?
特殊
在 Java 中,\ 表示:我要插入一个正则表达式的反斜线,所以其后的字符具有特殊的意义。
在 Java 中,\ 表示:我要插入一个正则表达式的反斜线,所以其后的字符具有特殊的意义。
在正则表达式中,两个 \ 代表其他语言中的一个 \,
一位数字的正则表达式是 \d,一个普通的反斜杠是 \\。
网友评论