これを使ってみましたがうまくいきませんでした-
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]
それ自体が文字範囲AZ/azにない文字を置き換えることに注意する必要があります。つまりé
、ß
などの特殊文字やキリル文字などは削除されます。
これらの文字の置換が不要な場合は、代わりに事前定義された文字クラスを使用してください。
str.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のような他の言語とは対照的に、正規表現の前後にスラッシュ(/
)やその他の区切り文字を付ける必要はありません。
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
したがって、パターンに含まれていないすべての文字に置き換えられます
私はファイル名を作成するためにこの方法を作りました:
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();
}
たとえばドイツ語の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を参照)。
Guavaを使用すると、さまざまなタイプの基準を簡単に組み合わせることができます。特定のソリューションについては、以下を使用できます。
value = CharMatcher.inRange('0', '9')
.or(CharMatcher.inRange('a', 'z')
.or(CharMatcher.inRange('A', 'Z'))).retainFrom(value)
簡単な方法:
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
GuavaのCharMatcherは、簡潔なソリューションを提供します。
output = CharMatcher.javaLetterOrDigit().retainFrom(input);