La idea es leer una cadena y verificar que no contenga ningún carácter numérico. Por tanto, algo como "smith23" no sería aceptable.
81
¿Qué deseas? ¿Rapidez o sencillez? Para mayor velocidad, opte por un enfoque basado en bucles. Para simplificar, opte por un enfoque basado en RegEx de una línea.
Velocidad
public boolean isAlpha(String name) {
char[] chars = name.toCharArray();
for (char c : chars) {
if(!Character.isLetter(c)) {
return false;
}
}
return true;
}
Sencillez
public boolean isAlpha(String name) {
return name.matches("[a-zA-Z]+");
}
char[]
se codificará como UTF-16. Esto significa que un glifo de varios caracteres (donde ambos caracteres están en los rangos sustitutos) no se reconocerá como una letra cuando se examine individualmente usandoCharacter.isLetter(char)
. (Consulte docs.oracle.com/javase/7/docs/api/java/lang/… ) En su lugar, necesitaría usar una combinación deString.codePointAt()
yCharacter.isLetter(int)
. Por supuesto, si sabe con certeza que los caracteres en su cadena están en ASCII o rangos codificados de un solo carácter extendidos, entonces la respuesta anterior funcionará.Expresiones lambda de Java 8. Rápido y sencillo.
boolean allLetters = someString.chars().allMatch(Character::isLetter);
fuente
O si está utilizando Apache Commons, [StringUtils.isAlpha ()] .
fuente
Primer patrón de importación:
import java.util.regex.Pattern;
Entonces usa este simple código:
String s = "smith23"; if (Pattern.matches("[a-zA-Z]+",s)) { // Do something System.out.println("Yes, string contains letters only"); }else{ System.out.println("Nope, Other characters detected"); }
Esto dará como resultado:
fuente
Usé esta expresión regular
(".*[a-zA-Z]+.*")
. Conif not
instrucción evitará todas las expresiones que tengan una letra antes, al final o entre cualquier tipo de otro carácter.String strWithLetters = "123AZ456"; if(! Pattern.matches(".*[a-zA-Z]+.*", str1)) return true; else return false
fuente
.*
al principio y al final no es correcto. Como pueden tener cualquier longitud e incluir dígitos,123smith123
sería un nombre válido. Sin embargo, algo como `` ^ [a-zA-Z] + $ `funcionaría, si es solo la palabra en la cadena.Una forma rápida de hacerlo es:
public boolean isStringAlpha(String aString) { int charCount = 0; String alphabet = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"; if (aString.length() == 0) { return false; //zero length string ain't alpha } for (int i = 0; i < aString.length(); i++) { for (int j = 0; j < alphabet.length(); j++) { if (aString.substring(i, i + 1).equals(alphabet.substring(j, j + 1)) || aString.substring(i, i + 1).equals(alphabet.substring(j, j + 1).toLowerCase())) { charCount++; } } if (charCount != (i + 1)) { System.out.println("\n**Invalid input! Enter alpha values**\n"); return false; } } return true; }
Porque no tiene que ejecutar todo
aString
para comprobar si no es una cadena alfa .fuente
private boolean isOnlyLetters(String s){ char c=' '; boolean isGood=false, safe=isGood; int failCount=0; for(int i=0;i<s.length();i++){ c = s.charAt(i); if(Character.isLetter(c)) isGood=true; else{ isGood=false; failCount+=1; } } if(failCount==0 && s.length()>0) safe=true; else safe=false; return safe; }
Sé que está un poco abarrotado. Lo estaba usando con mi programa y sentí el deseo de compartirlo con la gente. Puede decir si algún carácter de una cadena no es una letra o no. Úselo si desea algo fácil de aclarar y recordar.
fuente
La forma más rápida está abajo. Considerando que las letras son solo az, AZ.
public static void main( String[] args ){ System.out.println(bestWay("azAZpratiyushkumarsinghjdnfkjsaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa")); System.out.println(isAlpha("azAZpratiyushkumarsinghjdnfkjsaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa")); System.out.println(bestWay("azAZpratiyushkumarsinghjdnfkjsaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa1aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa")); System.out.println(isAlpha("azAZpratiyushkumarsinghjdnfkjsaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa1aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa")); } public static boolean bettertWay(String name) { char[] chars = name.toCharArray(); long startTimeOne = System.nanoTime(); for(char c : chars){ if(!(c>=65 && c<=90)&&!(c>=97 && c<=122) ){ System.out.println(System.nanoTime() - startTimeOne); return false; } } System.out.println(System.nanoTime() - startTimeOne); return true; } public static boolean isAlpha(String name) { char[] chars = name.toCharArray(); long startTimeOne = System.nanoTime(); for (char c : chars) { if(!Character.isLetter(c)) { System.out.println(System.nanoTime() - startTimeOne); return false; } } System.out.println(System.nanoTime() - startTimeOne); return true; }
El tiempo de ejecución se calcula en nano segundos. Puede variar de un sistema a otro.
5748//bettertWay without numbers true 89493 //isAlpha without numbers true 3284 //bettertWay with numbers false 22989 //isAlpha with numbers false
fuente
Verifique esto, supongo que esto es de ayuda porque funciona en mi proyecto, así que una vez que verifique este código
if(! Pattern.matches(".*[a-zA-Z]+.*[a-zA-Z]", str1)) { String not contain only character; } else { String contain only character; }
fuente
String expression = "^[a-zA-Z]*$"; CharSequence inputStr = str; Pattern pattern = Pattern.compile(expression); Matcher matcher = pattern.matcher(inputStr); if(matcher.matches()) { //if pattern matches } else { //if pattern does not matches }
fuente
Intente usar expresiones regulares: String.matches
fuente
public boolean isAlpha(String name) { String s=name.toLowerCase(); for(int i=0; i<s.length();i++) { if((s.charAt(i)>='a' && s.charAt(i)<='z')) { continue; } else { return false; } } return true; }
fuente
A12341
volveríatrue
. -1continue
bloque.public boolean isAlpha(String name) { String s = name.toLowerCase(); for (int i = 0; i < s.length(); i++) { if ((s.charAt(i) < 'a' || s.charAt(i) > 'z')) { return false; } } return true; }
Use el método StringUtils.isAlpha () y le hará la vida más simple.
fuente