Я попытался использовать это, но не работал -
return value.replaceAll("/[^A-Za-z0-9 ]/", "");
Я попытался использовать это, но не работал -
return value.replaceAll("/[^A-Za-z0-9 ]/", "");
Используйте [^A-Za-z0-9]
.
Примечание. Удалено пространство, так как это обычно не считается буквенно-цифровым.
Попробуйте
return value.replaceAll("[^A-Za-z0-9]", "");
или
return value.replaceAll("[\\W]|_", "");
Вы должны знать, что [^a-zA-Z]
заменит символы, которые не являются самими в диапазоне символов A-Z/a-z. Это означает, что специальные символы, такие как é
, ß
и т.д. Или кириллические символы, будут удалены.
Если замена этих символов не нужна, используйте вместо этого предопределенные классы символов:
someString.replaceAll("[^\\p{IsAlphabetic}^\\p{IsDigit}]", "");
PS: \p{Alnum}
не достигает этого эффекта, он действует так же, как [A-Za-z0-9]
.
return value.replaceAll("[^A-Za-z0-9 ]", "");
Это останется без изменений. Я предполагаю, что вы хотите. В противном случае удалите пробел из регулярного выражения.
Вы также можете попробовать это более простое регулярное выражение:
str = str.replaceAll("\\P{Alnum}", "");
Регулярные выражения Java не требуют, чтобы вы поместили прямую слэш (/
) или любой другой разделитель вокруг регулярного выражения, в отличие от других языков, таких как Perl.
Я создал этот метод для создания имен файлов:
public static String safeChar(String input)
{
char[] allowed = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ-_".toCharArray();
char[] charArray = input.toString().toCharArray();
StringBuilder result = new StringBuilder();
for (char c : charArray)
{
for (char a : allowed)
{
if(c==a) result.append(a);
}
}
return result.toString();
}
value.replaceAll("[^A-Za-z0-9]", "")
[^abc]
Когда в квадратных скобках появляется символ^
как первый символ в квадратных скобках, он отменяет шаблон. Этот шаблон соответствует любому символу, кроме a или b или c.
Глядя на ключевое слово как две функции:
[(Pattern)] = match(Pattern)
[^(Pattern)] = notMatch(Pattern)
Более того, в отношении шаблона:
AZ = all characters included from A to Z
az = all characters included from a to z
0=9 = all characters included from 0 to 9
Поэтому он заменит все символы, НЕ включенные в шаблон
Простой метод:
public boolean isBlank(String value) {
return (value == null || value.equals("") || value.equals("null") || value.trim().equals(""));
}
public String normalizeOnlyLettersNumbers(String str) {
if (!isBlank(str)) {
return str.replaceAll("[^\\p{L}\\p{Nd}]+", "");
} else {
return "";
}
}
public static void main(String[] args) {
String value = " Chlamydia_spp. IgG, IgM & IgA Abs (8006) ";
System.out.println(value.replaceAll("[^A-Za-z0-9]", ""));
}
вывод: ChlamydiasppIgGIgMIgAAbs8006
Github: https://github.com/AlbinViju/Learning/blob/master/StripNonAlphaNumericFromString.java
Если вы хотите также разрешить алфавитно-цифровые символы, которые не относятся к набору символов ascii, как, например, немецкие умлауты, вы можете использовать следующее решение:
String value = "your value";
// this could be placed as a static final constant, so the compiling is only done once
Pattern pattern = Pattern.compile("[^\\w]", Pattern.UNICODE_CHARACTER_CLASS);
value = pattern.matcher(value).replaceAll("");
Обратите внимание, что использование флага UNICODE_CHARACTER_CLASS может повлиять на снижение производительности (см. Javadoc этого флага)
Используя Guava, вы можете легко комбинировать различные типы критериев. Для вашего конкретного решения вы можете использовать:
value = CharMatcher.inRange('0', '9')
.or(CharMatcher.inRange('a', 'z')
.or(CharMatcher.inRange('A', 'Z'))).retainFrom(value)