English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

Объяснение структуры Java регулярного выражения «re?».

Подразделение / символ «re?» соответствует 0 или 1 предшествующим выражениям.

Пример 1

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("Количество совпадений: " + count);
   }
}

Результат вывода

Количество совпадений: 1

Пример 2

Данный Java-программа принимает строку от пользователя, проверяет, содержит ли она буквы (два случая), а также принимает цифры.

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("Введите строку ввода: ");
      String input = sc.nextLine();
      //Создание объекта Pattern
      Pattern p = Pattern.compile(regex);
      //Создание объекта Matcher
      Matcher m = p.matcher(input);
      if(m.find()) {
         System.out.println("Match найден");
      } else {
         System.out.println("Match не найден");
      }
   }
}

Вывод 1

Введите строку ввода:
sample text
Match найден

Вывод 2

Введите строку ввода:
sample text 34 56
Match найден

Вывод 3

Введите строку ввода:
32 89 45 63
Match не найден
Основной учебник
Рекомендуется также