java正则匹配
1. java 正则表达式是什么
不同情况下的正则表达式:
匹配首尾空格的正则表达式:(^s*)|(s*$)。
匹配html标签的正则表达式:<(.*)>(.*)</(.*)>|<(.*)/>。
配空行的正则表达式: [s| ]* 。
整数或者小数:^[0-9]+.{0,1}[0-9]{0,2}$。
只能输入数字:"^[0-9]*$"。
只能输入n位的数字:"^d{n}$"。
只能输入至少n位的数字:"^d{n,}$"。
只能输入m~n位的数字:。"^d{m,n}$"
只能输入零和非零开头的数字:"^(0|[1-9][0-9]*)$"。
只能输入有两位小数的正实数:"^[0-9]+(.[0-9]{2})?$"。
只能输入有1~3位小数的正实数:"^[0-9]+(.[0-9]{1,3})?$"。
只能输入非零的正整数:"^+?[1-9][0-9]*$"。
只能输入非零的负整数:"^-[1-9][]0-9"*$。
只能输入长度为3的字符:"^.{3}$"。
只能输入由26个英文字母组成的字符串:"^[A-Za-z]+$"。
只能输入由26个大写英文字母组成的字符串:"^[A-Z]+$"。
只能输入由26个小写英文字母组成的字符串:"^[a-z]+$"。
只能输入由数字和26个英文字母组成的字符串:"^[A-Za-z0-9]+$"。
只能输入由数字、26个英文字母或者下划线组成的字符串:"^w+$"。
验证用户密码:"^[a-zA-Z]w{5,17}$"正确格式为:以字母开头,长度在6~18之间,只能包含字符、数字和下划线。
验证是否含有^%&',;=?$"等字符:"[^%&',;=?$x22]+"。
只能输入汉字:"^[u4e00-u9fa5]{0,}$"。
验证Email地址:"^w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*$"。
验证一年的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]。
应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)String.prototype.len=function(){returnthis.replace(/[^x00-xff]/g,"aa").length;}。
2. java正则表达式 如何全局匹配
楼上有个说的很对,用while(m.find())。。。。。
具体就是:
while(m.find())
{
// 处理
String string = m.group();
}
// while中的find,是进行一次搜索,发现后即找到aab,进行循环体中处理,,然后再从上次找的的地方继续向后find。。。。。。。。。直到结束
3. Java 正则匹配
我来写正则,已测试:
importjava.util.regex.Matcher;
importjava.util.regex.Pattern;
publicclassTest1{
publicstaticvoidmain(String[]args){
Stringptn="(<ahref=[^<]*>)([u4e00-u9fa5]+)(</a>)";//([^<])(/a)
Patternp=Pattern.compile(ptn);
Strings="<ahref=">看</a>啊打发<ahref=ajdfajdk>虹</a>";
Matcherm=p.matcher(s);
while(m.find()){
System.out.println(m.group(0));
}
}
}
如果你网页数据中还有其它<a href = ....>ad</a>,告诉我,我把匹配写得再详细点
4. java正则表达式匹配
java里的正则表达式默认只匹配一行
若要支持匹配换行符,在建Pattern时使用两个参数的那个方法,加上参数Pattern.DOTALL
Pattern p = Pattern.compile("\\d+.{1,2}\\d{2}:\\d{2};\\d{2},\\d{3}",Pattern.DOTALL);
5. java正则匹配出所有类方法
java正则表达式提取需要用到Matcher类。
正则规则就是“一个数字加上大于等于0个非数字再加上结束符”
Pattern pattern
= Pattern.compile("(\\d)[^\\d]*$")
Matcher matcher
= pattern.matcher(s)
if(matcher.find())
System.out.println
(matcher.group(1)); } }
6. Java匹配正则表达式的实现
import java.util.ArrayList;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class Test {
public static void main(String[] args) {
Pattern pp = Pattern.compile("\\(|\\)|/|\\*|\\+|\\-|\\d*\\.\\d*|\\d*");
Matcher mm = pp.matcher("(10.0-54)*45+(32+5.4)/(2+1)");
List<String> values = new ArrayList<String>();
while(mm.find()){
values.add(mm.group());
}
String[] value = new String[values.size()];
values.toArray(value);
for(String str : value){
System.out.println(str);
}
}
}
7. java 正则匹配
没太明白你要匹配啥 <[n]>xxxxxxx</[n]> 你是要匹配<[n]> </[n]>之间的内容?
8. java正则表达式
你可以使用零宽断言来实现这个拆分。
比如题目中的要求可以使用正则:(?<!\),
你也可以使用JAVA正则表达式在线测试在线测试java正则表达式。
题目的测试结果如下:
9. java正则匹配
按照你的要求分割字符串的Java程序如下
publicclassDD{
publicstaticvoidmain(String[]args){
Stringstr="asd*dasd**asd*asd";
String[]s=str.split("(\*)+");
for(inti=0;i<s.length;i++){
System.out.println("被分割的字符串下标为"+i+"字符串为"+s[i]);
}
}
}
运行结果
被分割的字符串下标为 0 字符串为 asd
被分割的字符串下标为 1 字符串为 dasd
被分割的字符串下标为 2 字符串为 asd
被分割的字符串下标为 3 字符串为 asd
10. java 正则匹配目录
Java正则
"第(.*?)章\\s+(.*?)\\s"