###-9999
[A-Z]{3})(-)(\\d{4}
请注意,正则表达式的计算成本可能很高,因为每次运行都必须对其进行编译。因此,使用预先编译的模式有助于降低这种成本。
下面是来自该来源的基准的一个示例:
Time for String: 67.693 ms
Time for Pattern: 12.178 ms
以下是您的学生ID场景的可运行方法:
import java.util.List;
import java.util.regex.Pattern;
class Patterns {
public static final String STUDENT_ID_REGEX = "[A-Z]{3}-[0-9]{4}";
private static final Pattern STUDENT_ID_PATTERN = Pattern.compile(STUDENT_ID_REGEX);
public static boolean isStudentId(String candidate) {
return STUDENT_ID_PATTERN.matcher(candidate).matches();
}
}
public class RegexTest {
public static void main(String[] args) {
List<String> studentIds = List.of("ABC-1234", "ABC_1234", "AB-1234", "ABC-123", "abc-1234", "aBc-1234", "ABCD-A123", "SomeString", "123-ABCD");
studentIds.forEach(id -> {
System.out.println(id + " matches " + Patterns.STUDENT_ID_REGEX + "? " + Patterns.isStudentId(id));
});
}
}
ABC-1234 matches [A-Z]{3}-[0-9]{4}? true
ABC_1234 matches [A-Z]{3}-[0-9]{4}? false
AB-1234 matches [A-Z]{3}-[0-9]{4}? false
ABC-123 matches [A-Z]{3}-[0-9]{4}? false
abc-1234 matches [A-Z]{3}-[0-9]{4}? false
aBc-1234 matches [A-Z]{3}-[0-9]{4}? false
ABCD-A123 matches [A-Z]{3}-[0-9]{4}? false
SomeString matches [A-Z]{3}-[0-9]{4}? false
123-ABCD matches [A-Z]{3}-[0-9]{4}? false
AdoptOpenJDK jdk-16.0.1.9-hotspot
问题内容: 当字符串以数字开头时,我需要匹配,然后是一个点,然后是一个空格和1个或多个大写字符。匹配必须发生在字符串的开头。我有以下字符串。 我尝试过的正则表达式是: 它不匹配。一个有效的正则表达式将对这个问题有什么作用? 问题答案: (对不起,我先前的错误。大脑现在坚定地投入了。嗯,也许。) 这有效: 分解: =字符串开头 =一个或多个数字 (之所以转义,是因为它在字符串中,因此) =文字(或者
问题内容: 我从以下格式的文件中获取输入: 现在,我想在我的Java代码中读取int1,int2,int3和int4。我该如何在Java中使用正则表达式匹配。谢谢。 问题答案: 为了避免空值:
有没有人试图描述与正则表达式匹配的正则表达式? 由于重复的关键字,这个主题几乎不可能在网上找到。 它可能在实际应用程序中不可用,因为支持正则表达式的语言通常具有解析它们的方法,我们可以将其用于验证,以及一种在代码中分隔正则表达式的方法,可用于搜索目的。 但是我仍然想知道匹配所有正则表达式的正则表达式是什么样子的。应该可以写一个。
我们得到了一些这样的内容:
主要内容:基本模式匹配,字符簇,确定重复出现基本模式匹配 一切从最基本的开始。模式,是正则表达式最基本的元素,它们是一组描述字符串特征的字符。模式可以很简单,由普通的字符串组成,也可以非常复杂,往往用特殊的字符表示一个范围内的字符、重复出现,或表示上下文。例如: 这个模式包含一个特殊的字符 ^,表示该模式只匹配那些以 once 开头的字符串。例如该模式与字符串 "once upon a time" 匹配,与 "There once was