다음은 주어진 입력에서 알파벳과 일치하는 정규식입니다 -
"^[a-zA-Z]*$"
어디,
- ^는 문장의 시작과 일치합니다.
- [a-zA-z]는 소문자 및 대문자와 일치합니다.
- *는 0회 이상 발생을 나타냅니다.
- &는 줄의 끝을 나타냅니다.
예시 1
import java.util.Scanner;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class ContainsAlphabetExample {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String names[] = new String[5];
for(int i=0; i<names.length;i++){
System.out.println("Enter your name: ");
names[i] = sc.nextLine();
}
//Regular expression to accept English alphabet
String regex = "^[a-zA-Z]*$";
//Creating a pattern object
Pattern pattern = Pattern.compile(regex);
for (String name : names) {
//Creating a Matcher object
Matcher matcher = pattern.matcher(name);
if(matcher.matches()) {
System.out.println(name+" is a valid name");
} else {
System.out.println(name+" is not a valid name");
}
}
}
} 출력
Enter your name: krishna Enter your name: kasyap Enter your name: maruthi# Enter your name: Sai_Ram Enter your name: Vani.Viswanath krishna is a valid name kasyap is a valid name maruthi# is not a valid name Sai_Ram is not a valid name Vani.Viswanath is not a valid name
예시 2
import java.util.Scanner;
public class Just {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.println("Enter your name: ");
String name = sc.nextLine();
String regex = "^[a-zA-Z]*$";
boolean result = name.matches(regex);
if(result) {
System.out.println("Given name is valid");
} else {
System.out.println("Given name is not valid");
}
}
} 출력
Enter your name: vasu#dev Given name is not valid