我试过用这个,但没有用
return value.replaceAll("/[^A-Za-z0-9 ]/", "");
我试过用这个,但没有用
return value.replaceAll("/[^A-Za-z0-9 ]/", "");
当前回答
使用[^ A-Za-z0-9]。
注意:删除了空格,因为它通常不被认为是字母数字。
其他回答
如果你也想允许不属于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)。
您应该知道[^a-zA-Z]将替换字符本身不是在字符范围A-Z/ A-Z中的字符。这意味着像é, ß等特殊字符或西里尔字符等将被删除。
如果不需要替换这些字符,可以使用预定义的字符类:
str.replaceAll("[^\\p{IsAlphabetic}\\p{IsDigit}]", "");
PS: \p{Alnum}不能达到这种效果,它的作用与[A-Za-z0-9]相同。
Java的正则表达式不需要在正则表达式周围加上正斜杠(/)或任何其他分隔符,这与Perl等其他语言不同。
简单的方法:
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 "";
}
}
Try
return value.replaceAll("[^A-Za-z0-9]", "");
or
return value.replaceAll("[\\W]|_", "");