English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
L'espressione regolare /carattere speciale "re?" corrisponde 0 o 1 alla espressione precedente.
import java.util.regex.Matcher; import java.util.regex.Pattern; public class RegexExample { public static void main( String args[] ) { String regex = "Wel?"; String input = "Welcome to w3codebox"; Pattern p = Pattern.compile(regex); Matcher m = p.matcher(input); int count = 0; while(m.find()) { count++; } System.out.println("Numero di corrispondenze: "+count); } }
Risultato dell'output
Numero di corrispondenze: 1
Il seguente programma Java accetta una stringa dall'utente, verifica se contiene lettere (due casi) e accetta anche numeri.
import java.util.Scanner; import java.util.regex.Matcher; import java.util.regex.Pattern; public class Test { public static void main( String args[] ) { String regex = "[a-zA-Z][0-9]?"; Scanner sc = new Scanner(System.in); System.out.println("Inserisci una stringa di input: "); String input = sc.nextLine(); //Creazione di un oggetto Pattern Pattern p = Pattern.compile(regex); //Creazione di un oggetto Matcher Matcher m = p.matcher(input); if(m.find()) { System.out.println("Corrispondenza trovata"); } else { System.out.println("Non è stata trovata corrispondenza"); } } }
Inserisci una stringa di input: testo campione Corrispondenza trovata
Inserisci una stringa di input: testo campione 34 56 Corrispondenza trovata
Inserisci una stringa di input: 32 89 45 63 Non è stata trovata corrispondenza