我试过用这个,但没有用

return value.replaceAll("/[^A-Za-z0-9 ]/", "");

当前回答

解决方案:

价值。replaceAll(“[^ A-Za-z0-9] ", " ")

解释:

(^ abc) 当插入符号^作为方括号内的第一个字符出现时,将取消该模式。此模式匹配除a或b或c之外的任何字符。

将关键字看作两个函数:

[(图案)]= match(图案) [^(图案)]= notMatch(图案)

此外,关于一种模式:

A-Z =从A到Z的所有字符 a-z =从a到z的所有字符 0=9 =从0到9的所有字符

因此,它将替换模式中包含的所有字符NOT

其他回答

Java的正则表达式不需要在正则表达式周围加上正斜杠(/)或任何其他分隔符,这与Perl等其他语言不同。

使用番石榴,您可以轻松地组合不同类型的标准。对于您的具体解决方案,您可以使用:

value = CharMatcher.inRange('0', '9')
        .or(CharMatcher.inRange('a', 'z')
        .or(CharMatcher.inRange('A', 'Z'))).retainFrom(value)

我创建了这个方法来创建文件名:

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();
}

Try

return value.replaceAll("[^A-Za-z0-9]", "");

or

return value.replaceAll("[\\W]|_", "");

如果你也想允许不属于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)。