最近开发中,使用到了正则表达式,记录一下语法以及Java代码示例。
正则表达式简介
一种用来描述字符串模式的工具,可以用来匹配
、查找
和替换
文本中符合特定模式的字符串
。正则表达式由普通字符
(例如字母、数字)和元字符
(例如. * ?)组成,通过组合这些字符和元字符来定义一个匹配模式
。
语法
1. 普通字符
普通字符包括字母、数字和一些特殊字符,例如 a , 1 , @ 等。
2. 元字符
- . :匹配任意单个字符,除了换行符。
- .
*
:* 匹配前面的字符零次或多次。 - .
+
:+ 匹配前面的字符一次或多次。 - ? :匹配前面的字符零次或一次。
- ^ :匹配字符串的开始。
- $ :匹配字符串的结束。
- [] :匹配括号内的任意一个字符。
- () :用于捕获匹配的内容。
- | :用于表示“或”关系,匹配多个模式中的一个。
- `:用于转义特殊字符,使其成为普通字符。
3. 字符类
- [abc] :匹配 a , b , c 中的任意一个字符。
- [a-z] :匹配任意小写字母。
- [A-Z] :匹配任意大写字母。
- [0-9] :匹配任意数字。
4. 预定义字符类
- \d :匹配任意数字,相当于 [0-9] 。
- \w :匹配任意字母、数字、下划线,相当于 [a-zA-Z0-9_] 。
- \s :匹配任意空白字符,包括空格、制表符等。
5. 量词
- {n} :匹配前面的字符恰好n次。
- {n,} :匹配前面的字符至少n次。
- {n,m} :匹配前面的字符至少n次,最多m次。
6. 贪婪与非贪婪
- 贪婪匹配:尽可能多地匹配符合条件的字符。
- 非贪婪匹配:尽可能少地匹配符合条件的字符,在
量词
后加上 ?`表示非贪婪匹配。
Java代码示例
下面是使用正则表达式来验证和提取电子邮件地址的简单示例:
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class EmailValidator {
private static final String EMAIL_REGEX = "^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$";
/**
* 验证电子邮件地址是否符合指定的正则表达式模式
* @param email
* @return
*/
public static boolean isValidEmail(String email) {
Pattern pattern = Pattern.compile(EMAIL_REGEX);
Matcher matcher = pattern.matcher(email);
return matcher.matches();
}
/**
* 从电子邮件地址中提取域名
* @param email
* @return
*/
public static String extractDomain(String email) {
Pattern pattern = Pattern.compile("@([a-zA-Z0-9.-]+)\\.[a-zA-Z]{2,}$");
Matcher matcher = pattern.matcher(email);
if (matcher.find()) {
return matcher.group(1);
}
return null;
}
public static void main(String[] args) {
String email1 = "myemail@example.com";
String email2 = "invalid_email.com";
System.out.println(email1 + " is a valid email: " + isValidEmail(email1)); //true
System.out.println(email2 + " is a valid email: " + isValidEmail(email2)); //false
String domain = extractDomain(email1);
System.out.println(domain); //example
}
}
总结
本文记录一下正则表达式语法以及Java代码示例。
希望对看到本文的你有帮助。
上一篇 Java 正则表达式 group、start、end 方法使用注意事项及详解。 |
记得点赞收藏哦!!!
| 下一篇 SpringBoot整合SpringDataJPA实现增删改查(详细版)。 |