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

Construcción de expresión regular "[^ ...]" en Java

Expresión subordinada/Caracteres meta [^ ...] Coincide con cualquier carácter individual, no con paréntesis.

ejemplo1

import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class SpecifiedCharacters {
   public static void main( String args[] ) {
      String regex = "[^hwtyoupi]";
      String input = "Hola, ¿cómo estás, bienvenido a w3codebox";
      Pattern p = Pattern.compile(regex);
      Matcher m = p.matcher(input);
      int count = 0;
      while(m.find()) {
         count++;
      }
      System.out.println("Número de coincidencias:");+;
   }
}

Resultado de salida

Número de coincidencias: 21

ejemplo2

El siguiente programa Java recibe5una cadena y muestra las cadenas que no contienen letras inglesas/palabras.

import java.util.Scanner;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class RegexExample {
   public static void main( String args[] ) {
      String regex = "^.*^[^a-zA-Z].*$";
      Scanner sc = new Scanner(System.in);
      System.out.println("Ingrese 5 cadenas de entrada: ");
      String input[] = new String[5];
      for(int i=0; i<5; i++) {
         input[i] = sc.nextLine();
      }
      //Crear un objeto Pattern
      Pattern p = Pattern.compile(regex);
      System.out.println("cadenas que no contienen el alfabeto inglés: ");
      for(int i=0; i<5;i++) {
         //Crear un objeto Matcher
         Matcher m = p.matcher(input[i]);
         if(m.find()) {
            System.out.println(m.group());
         }
      }
   }
}

Resultado de salida

Ingrese 5 cadenas de entrada:
1234*5
*&%
ejemplo
prueba
datos23
cadenas que no contienen el alfabeto inglés:
1234*5
*&%