java代码的正则表达式 java的正则表达式的使用

java正则表达式Java 正则表达式和 Perl 的是最为相似的,正则表达式就是规则表达式 。
Java中正则表达式与之前使用的Python是有区别的,区别在于Java对于反斜线(\)处理的不同 。在Python中”\d”表示 匹配一位数字(0-9),而Java中匹配一位数字(0-9),需要的正则表达式为”\\d” 。不过换行符和制表符只需要单反斜线“\n\t” 。
正则表达式定义了字符串的模式 。可以用来搜索、编辑或处理文本 。不仅限于某一种语言,但是在每种语言中有细微的差别 。
Java中什么是正则表达式常用的正则表达式大全:
(1) "^\d $"//非负整数(正整数0)
(2) "^[0-9]*[1-9][0-9]*$"//正整数
(3) "^((-\d )|(0 ))$"//非正整数(负整数0)
(4) "^-[0-9]*[1-9][0-9]*$"//负整数
(5) "^-?\d $"//整数
(6) "^\d (\.\d )?$"//非负浮点数(正浮点数0)
(7) "^(([0-9] \.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9] )|([0-9]*[1-9][0-9]*))$"//正浮点数
(8) "^((-\d (\.\d )?)|(0 (\.0 )?))$"//非正浮点数(负浮点数0)
(9) "^(-(([0-9] \.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9] )|([0-9]*[1-9][0-9]*)))$"//负浮点数
(10) "^(-?\d )(\.\d )?$"//浮点数
(11) "^[A-Za-z] $"//由26个英文字母组成的字符串
(12) "^[A-Z] $"//由26个英文字母的大写组成的字符串
(13) "^[a-z] $"//由26个英文字母的小写组成的字符串
(14) "^[A-Za-z0-9] $"//由数字和26个英文字母组成的字符串
(15) "^\w $"//由数字、26个英文字母或者下划线组成的字符串
(16) "^[\w-] (\.[\w-] )*@[\w-] (\.[\w-] ) $"//email地址
(17) "^[a-zA-z] ://(\w (-\w )*)(\.(\w (-\w )*))*(\?\S*)?$"//url
(18) /^(d{2}|d{4})-((0([1-9]{1}))|(1[1|2]))-(([0-2]([1-9]{1}))|(3[0|1]))$/ // 年-月-日
(19) /^((0([1-9]{1}))|(1[1|2]))/(([0-2]([1-9]{1}))|(3[0|1]))/(d{2}|d{4})$/ // 月/日/年
(20) "^([w-.] )@(([[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.)|(([w-] .) ))([a-zA-Z]{2,4}|[0-9]{1,3})(]?)$" //Emil
(21) /^((\ ?[0-9]{2,4}\-[0-9]{3,4}\-)|([0-9]{3,4}\-))?([0-9]{7,8})(\-[0-9] )?$/ //电话号码
(22) "^(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地址
(23)
(24) 匹配中文字符的正则表达式: [一-龥]
(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标记的正则表达式:/(.*).*/1|(.*) //
(79) 匹配首尾空格的正则表达式:(^s*)|(s*$)
(80) 匹配Email地址的正则表达式:w ([- .]w )*@w ([-.]w )*.w ([-.]w )*
(81) 匹配网址URL的正则表达式:http://([w-] .) [w-] (/[w- ./?%=]*)?
(82) 利用正则表达式限制网页表单里的文本框输入内容:
(83) 用正则表达式限制只能输入中文:οnkeyup="value=https://www.04ip.com/post/value.replace(/[^u4E00-u9FA5]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^u4E00-u9FA5]/g,''))"
(84) 用正则表达式限制只能输入全角字符: οnkeyup="value=https://www.04ip.com/post/value.replace(/[^uFF00-uFFFF]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^uFF00-uFFFF]/g,''))"
(85) 用正则表达式限制只能输入数字:οnkeyup="value=https://www.04ip.com/post/value.replace(/[^d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^d]/g,''))"
(86) 用正则表达式限制只能输入数字和英文:οnkeyup="value=https://www.04ip.com/post/value.replace(/[W]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^d]/g,''))"
(87) 整理:
(88) 匹配中文字符的正则表达式: [一-龥]
(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*)?$
或:^http:\/\/[A-Za-z0-9] \.[A-Za-z0-9] [\/=\?%\-_~`@[\]\': !]*([^\"\"])*$
(113) 邮政编码:^[1-9]\d{5}$
(114) 中文:^[Α-¥] $
(115) 电话号码:^((\d2,3 \d2,3)|(\d{3}\-))?(0\d2,3 0\d2,3|0\d{2,3}-)?[1-9]\d{6,7}(\-\d{1,4})?$
(116) 手机号码:^((\d2,3 \d2,3)|(\d{3}\-))?13\d{9}$
(117) 双字节字符(包括汉字在内):^\x00-\xff
(118) 匹配首尾空格:(^\s*)|(\s*$)(像vbscript那样的trim函数)
(119) 匹配HTML标记:(.*).*\/\1|(.*) \/
(120) 匹配空行:\n[\s| ]*\r
(121) 提取信息中的网络链接:(h|H)(r|R)(e|E)(f|F) *= *('|")?(\w|\\|\/|\.) ('|"| *|)?
(122) 提取信息中的邮件地址:\w ([- .]\w )*@\w ([-.]\w )*\.\w ([-.]\w )*
(123) 提取信息中的图片链接:(s|S)(r|R)(c|C) *= *('|")?(\w|\\|\/|\.) ('|"| *|)?
(124) 提取信息中的IP地址:(\d )\.(\d )\.(\d )\.(\d )
(125) 提取信息中的中国手机号码:(86)*0*13\d{9}
(126) 提取信息中的中国固定电话号码:(\d3,4 \d3,4|\d{3,4}-|\s)?\d{8}
(127) 提取信息中的中国电话号码(包括移动和固定电话):(\d3,4 \d3,4|\d{3,4}-|\s)?\d{7,14}
(128) 提取信息中的中国邮政编码:[1-9]{1}(\d ){5}
(129) 提取信息中的浮点数(即小数):(-?\d*)\.?\d
(130) 提取信息中的任何数字 :(-?\d*)(\.\d )?
(131) IP:(\d )\.(\d )\.(\d )\.(\d )
(132) 电话区号:/^0\d{2,3}$/
(133) 腾讯QQ号:^[1-9]*[1-9][0-9]*$
(134) 帐号(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
(135) 中文、英文、数字及下划线:^[一-龥_a-zA-Z0-9] $
希望对您有所帮助!~
关于java正则表达式^ 和 $ 他们是分别用来匹配字符串的开始和结束,以下分别举例说明:
【java代码的正则表达式 java的正则表达式的使用】"^The": 开头一定要有"The"字符串;
"of despair$": 结尾一定要有"of despair" 的字符串;
那么,
"^abc$": 就是要求以abc开头和以abc结尾的字符串,实际上是只有abc匹配 。
"notice": 匹配包含notice的字符串 。
你可以看见如果你没有用我们提到的两个字符(最后一个例子),就是说 模式(正则表达式) 可以出现在被检验字符串的任何地方,你没有把他锁定到两边 。
接着,说说 '*', ' ',和 '?',
他们用来表示一个字符可以出现的次数或者顺序. 他们分别表示:
"zero or more"相当于{0,},
"one or more"相当于{1,},
"zero or one."相当于{0,1}, 这里是一些例子:
"ab*": 和ab{0,}同义,匹配以a开头,后面可以接0个或者N个b组成的字符串("a", "ab", "abbb", 等);
"ab ": 和ab{1,}同义,同上条一样,但最少要有一个b存在 ("ab", "abbb", 等.);
"ab?":和ab{0,1}同义,可以没有或者只有一个b;
"a?b $": 匹配以一个或者0个a再加上一个以上的b结尾的字符串.
要点, '*', ' ',和 '?'只管它前面那个字符.
你也可以在大括号里面限制字符出现的个数 , 比如
"ab{2}": 要求a后面一定要跟两个b(一个也不能少)("abb");
"ab{2,}": 要求a后面一定要有两个或者两个以上b(如"abb", "abbbb", 等.);
"ab{3,5}": 要求a后面可以有2-5个b("abbb", "abbbb", or "abbbbb").
现在我们把一定几个字符放到小括号里,比如:
"a(bc)*": 匹配 a 后面跟0个或者一个"bc";
"a(bc){1,5}": 一个到5个 "bc."
还有一个字符 '│', 相当于OR 操作:
"hi│hello": 匹配含有"hi" 或者 "hello" 的 字符串;
"(b│cd)ef": 匹配含有 "bef" 或者 "cdef"的字符串;
"(a│b)*c": 匹配含有这样多个(包括0个)a或b , 后面跟一个c的字符串;
一个点('.')可以代表所有的单一字符,不包括"\n"
如果,要匹配包括"\n"在内的所有单个字符,怎么办?
对了,用'[\n.]'这种模式.
"a.[0-9]": 一个a加一个字符再加一个0到9的数字
"^.{3}$": 三个任意字符结尾 .
中括号括住的内容只匹配一个单一的字符
"[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能够解释 , 你必须在这些字符面前后加'',并且将一些字符转义.
不要忘记在中括号里面的字符是这条规路的例外?在中括号里面, 所有的特殊字符,包括(''), 都将失去他们的特殊性质 "[*\ ?{}.]"匹配含有这些字符的字符串.
还有,正如regx的手册告诉我们: "如果列表里含有 ']', 最好把它作为列表里的第一个字符(可能跟在'^'后面). 如果含有'-', 最好把它放在最前面或者最后面, or 或者一个范围的第二个结束点[a-d-0-9]中间的‘-’将有效.
看了上面的例子,你对{n,m}应该理解了吧.要注意的是,n和m都不能为负整数,而且n总是小于m. 这样,才能 最少匹配n次且最多匹配m次. 如"p{1,5}"将匹配 "pvpppppp"中的前五个p.
下面说说以\开头的
\b 书上说他是用来匹配一个单词边界,就是...比如've\b',可以匹配love里的ve而不匹配very里有ve
\B 正好和上面的\b相反.例子我就不举了
.....突然想起来....可以到 看看其它用\ 开头的语法
好,我们来做个应用:
如何构建一个模式来匹配 货币数量 的输入
构建一个匹配模式去检查输入的信息是否为一个表示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字符串中可能会出现错误 (很普遍的错误).
现在,我们已经可以确认字符串了, 我们现在把所有逗号都去掉 str_replace(",", "", $money) 然后在把类型看成 double然后我们就可以通过他做数学计算了.
java正则表达式怎么书写?正则表达式 , 又称规则表达式 。(英语:Regular Expression,在代码中常简写为regex、regexp或RE),计算机科学的一个概念 。正则表达式通常被用来检索、替换那些符合某个模式(规则)的文本 。
下面介绍具体的方法 。
1、步骤一: 新建一个工程和类
我们在这个类中开发相关的代码,先看看 java.util.regex 这个包吧 。
2、步骤二 : 类 Pattern 的使用
类Pattern ,其一个对象就代表一种指定的正则表达式,我们通过这个类和一些正则表达式的规则来生成自己想要的字符串匹配规则!
这个类,你无法通过 new 来创建对象,其提供了一个静态方法 compile("正则规则串")来创建对象 , 比如我们想要一个以 "java" 开头的字符串匹配规则,我们会用如下代码 Pattern 对象 :
Pattern pattern = Pattern.compile("^java");
注意 : ^ 这个符号是正则表达式中的规则,表示字符串的开头!关于其他规则 , 我们后面会有相关经验给大家逐一介绍!
3、步骤三 : 类 Matcher 的使用
类 Matcher,代表一个串在特定Pattern对象下的匹配结果 , 我们通过这个结果可以知道这个串是否符合我们的要求 (我们的具体要求在 Pattern 对象中体现?。?。使用方法为 :
// 先构建一个特定的 Pattern 对象
Pattern pattern = Pattern.compile("^java");
// 调用 Pattern 对象的 matcher 方法,传入一个串,得到匹配结果!
Matcher matcher = javaPrefixPattern.matcher("一个字符串");
4、步骤四 : 测试和总结
运行代码 , 查看程序运行效果!正则表达式的整个使用框架就是这样,其不同的应用场景基本就是不同的匹配规则!
总结 :正则表达式的彪悍,主要在于其很多成熟的规范的语义规则 , 通过这些规则的灵活使用 , 我们可以把一种复杂的匹配需求用一个规则串表达出来!
java 正则表达式是什么?常用的正则表达式大全:
(1)"^\d $"//非负整数(正整数0)
(2)"^[0-9]*[1-9][0-9]*$"//正整数
(3)"^((-\d )|(0 ))$"//非正整数(负整数0)
(4)"^-[0-9]*[1-9][0-9]*$"//负整数
(5)"^-?\d $"//整数
(6)"^\d (\.\d )?$"//非负浮点数(正浮点数0)
(7)"^(([0-9] \.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9] )|([0-9]*[1-9][0-9]*))$"//正浮点数
(8)"^((-\d (\.\d )?)|(0 (\.0 )?))$"//非正浮点数(负浮点数0)
(9)"^(-(([0-9] \.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9] )|([0-9]*[1-9][0-9]*)))$"//负浮点数
(10)"^(-?\d )(\.\d )?$"//浮点数
(11)"^[A-Za-z] $"//由26个英文字母组成的字符串
(12)"^[A-Z] $"//由26个英文字母的大写组成的字符串
(13)"^[a-z] $"//由26个英文字母的小写组成的字符串
(14)"^[A-Za-z0-9] $"//由数字和26个英文字母组成的字符串
(15)"^\w $"//由数字、26个英文字母或者下划线组成的字符串
(16)"^[\w-] (\.[\w-] )*@[\w-] (\.[\w-] ) $"//email地址
(17)"^[a-zA-z] ://(\w (-\w )*)(\.(\w (-\w )*))*(\?\S*)?$"//url
(18)/^(d{2}|d{4})-((0([1-9]{1}))|(1[1|2]))-(([0-2]([1-9]{1}))|(3[0|1]))$///年-月-日
(19)/^((0([1-9]{1}))|(1[1|2]))/(([0-2]([1-9]{1}))|(3[0|1]))/(d{2}|d{4})$/// 月/日/年
(20)"^([w-.] )@(([[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.)|(([w-] .) ))([a-zA-Z]{2,4}|[0-9]{1,3})(]?)$"//Emil
(21)/^((\ ?[0-9]{2,4}\-[0-9]{3,4}\-)|([0-9]{3,4}\-))?([0-9]{7,8})(\-[0-9] )?$///电话号码
(22)"^(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地址
(23)
(24)匹配中文字符的正则表达式: [一-龥]
(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)匹配帐号是否合法(字母开头java代码的正则表达式,允许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)^ 匹配输入字符串的开始位置 。如果设置java代码的正则表达式了 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)? 当该字符紧跟在任何一个其java代码的正则表达式他限制符 (*,, ?, {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标记的正则表达式:/(.*).*/1|(.*) //
(79)匹配首尾空格的正则表达式:(^s*)|(s*$)
(80)匹配Email地址的正则表达式:w ([- .]w )*@w ([-.]w )*.w ([-.]w )*
(81)匹配网址URL的正则表达式:http://([w-] .) [w-] (/[w- ./?%=]*)?
(82)利用正则表达式限制网页表单里的文本框输入内容:
(83)用正则表达式限制只能输入中文:οnkeyup="value=https://www.04ip.com/post/value.replace(/[^u4E00-u9FA5]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^u4E00-u9FA5]/g,''))"
(84)用正则表达式限制只能输入全角字符: οnkeyup="value=https://www.04ip.com/post/value.replace(/[^uFF00-uFFFF]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^uFF00-uFFFF]/g,''))"
(85)用正则表达式限制只能输入数字:οnkeyup="value=https://www.04ip.com/post/value.replace(/[^d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^d]/g,''))"
(86)用正则表达式限制只能输入数字和英文:οnkeyup="value=https://www.04ip.com/post/value.replace(/[W]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^d]/g,''))"
(87)整理:
(88)匹配中文字符的正则表达式: [一-龥]
(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*)?$
或:^http:\/\/[A-Za-z0-9] \.[A-Za-z0-9] [\/=\?%\-_~`@[\]\': !]*([^\"\"])*$
(113)邮政编码:^[1-9]\d{5}$
(114)中文:^[Α-¥] $
(115)电话号码:^((\d2,3 \d2,3)|(\d{3}\-))?(0\d2,3 0\d2,3|0\d{2,3}-)?[1-9]\d{6,7}(\-\d{1,4})?$
(116)手机号码:^((\d2,3 \d2,3)|(\d{3}\-))?13\d{9}$
(117)双字节字符(包括汉字在内):^\x00-\xff
(118)匹配首尾空格:(^\s*)|(\s*$)(像vbscript那样的trim函数)
(119)匹配HTML标记:(.*).*\/\1|(.*) \/
(120)匹配空行:\n[\s| ]*\r
(121)提取信息中的网络链接:(h|H)(r|R)(e|E)(f|F) *= *('|")?(\w|\\|\/|\.) ('|"| *|)?
(122)提取信息中的邮件地址:\w ([- .]\w )*@\w ([-.]\w )*\.\w ([-.]\w )*
(123)提取信息中的图片链接:(s|S)(r|R)(c|C) *= *('|")?(\w|\\|\/|\.) ('|"| *|)?
(124)提取信息中的IP地址:(\d )\.(\d )\.(\d )\.(\d )
(125)提取信息中的中国手机号码:(86)*0*13\d{9}
(126)提取信息中的中国固定电话号码:(\d3,4 \d3,4|\d{3,4}-|\s)?\d{8}
(127)提取信息中的中国电话号码(包括移动和固定电话):(\d3,4 \d3,4|\d{3,4}-|\s)?\d{7,14}
(128)提取信息中的中国邮政编码:[1-9]{1}(\d ){5}
(129)提取信息中的浮点数(即小数):(-?\d*)\.?\d
(130)提取信息中的任何数字 :(-?\d*)(\.\d )?
(131)IP:(\d )\.(\d )\.(\d )\.(\d )
(132)电话区号:/^0\d{2,3}$/
(133)腾讯QQ号:^[1-9]*[1-9][0-9]*$
(134)帐号(字母开头 , 允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
(135)中文、英文、数字及下划线:^[一-龥_a-zA-Z0-9] $
希望对您有所帮助java代码的正则表达式!~
java正则表达式是什么?在程序开发中,难免会遇到需要匹配、查找、替换、判断字符串的情况发生,而这些情况有时又比较复杂 , 如果用纯编码方式解决,往往会浪费程序员的时间及精力 。因此,学习及使用正则表达式,便成了解决这一矛盾的主要手段 。
正则表达式是一种可以用于模式匹配和替换的规范 , 一个正则表达式就是由普通的字符(例如字符a到z)以及特殊字符(元字符)组成的文字模式,它 用以描述在查找文字主体时待匹配的一个或多个字符串 。正则表达式作为一个模板,将某个字符模式与所搜索的字符串进行匹配 。
正则表达式的特点是:
1、灵活性、逻辑性和功能性非常强;
2、可以迅速地用极简单的方式达到字符串的复杂控制 。
3、对于刚接触的人来说 , 比较晦涩难懂 。
由于正则表达式主要应用对象是文本,因此它在各种文本编辑器场合都有应用,小到著名编辑器EditPlus,大到Microsoft Word、Visual Studio等大型编辑器 , 都可以使用正则表达式来处理文本内容 。
关于java代码的正则表达式和java的正则表达式的使用的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息 , 记得收藏关注本站 。

    推荐阅读