223

これを使ってみましたがうまくいきませんでした-

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

13 に答える 13

276

を使用し[^A-Za-z0-9]ます。

注:通常は英数字とは見なされないため、スペースを削除してください。

于 2009-11-26T20:30:59.980 に答える
139

試す

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

また

return value.replaceAll("[\\W]|_", "");
于 2009-11-26T20:33:36.063 に答える
79

[^a-zA-Z]それ自体が文字範囲AZ/azにない文字を置き換えることに注意する必要があります。つまりéßなどの特殊文字やキリル文字などは削除されます。

これらの文字の置換が不要な場合は、代わりに事前定義された文字クラスを使用してください。

 str.replaceAll("[^\\p{IsAlphabetic}\\p{IsDigit}]", "");

PS:\p{Alnum}この効果は得られず、と同じように機能し[A-Za-z0-9]ます。

于 2015-09-17T10:25:21.033 に答える
60
return value.replaceAll("[^A-Za-z0-9 ]", "");

これにより、スペースはそのまま残ります私はそれがあなたが望むものだと思います。それ以外の場合は、正規表現からスペースを削除します。

于 2009-11-26T20:31:16.583 に答える
22

この単純な正規表現を試すこともできます。

 str = str.replaceAll("\\P{Alnum}", "");
于 2013-08-06T12:17:46.010 に答える
11

Javaの正規表現では、たとえばPerlのような他の言語とは対照的に、正規表現の前後にスラッシュ(/)やその他の区切り文字を付ける必要はありません。

于 2009-11-26T20:39:19.917 に答える
9

解決:

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

説明:

[^abc] カレット^が角括弧内の最初の文字として表示される場合、パターンは無効になります。このパターンは、a、b、またはcを除くすべての文字に一致します。

キーワードを2つの機能として見る:

  • [(Pattern)] = match(Pattern)
  • [^(Pattern)] = notMatch(Pattern)

さらにパターンに関して:

  • A-Z = all characters included from A to Z

  • a-z = all characters included from a to z

  • 0=9 = all characters included from 0 to 9

したがって、パターンに含まれていないすべての文字に置き換えられます

于 2018-11-21T12:07:13.157 に答える
8

私はファイル名を作成するためにこの方法を作りました:

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();
}
于 2009-11-27T02:08:47.630 に答える
3

たとえばドイツ語のumlautのように、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を参照)。

于 2018-05-24T10:18:52.003 に答える
2

Guavaを使用すると、さまざまなタイプの基準を簡単に組み合わせることができます。特定のソリューションについては、以下を使用できます。

value = CharMatcher.inRange('0', '9')
        .or(CharMatcher.inRange('a', 'z')
        .or(CharMatcher.inRange('A', 'Z'))).retainFrom(value)
于 2018-10-04T07:45:04.693 に答える
1

簡単な方法:

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 "";
    }
}
于 2016-11-01T19:36:37.737 に答える
1
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

于 2017-08-23T15:21:51.150 に答える
1

GuavaのCharMatcherは、簡潔なソリューションを提供します。

output = CharMatcher.javaLetterOrDigit().retainFrom(input);
于 2019-10-28T07:56:38.177 に答える