0〜9およびピリオド以外のすべての文字と文字を削除しようとしています。私は使用してCharacter.isDigit()
いますが、10進数も削除されます。どうすれば10進数を保持できますか?
0〜9およびピリオド以外のすべての文字と文字を削除しようとしています。私は使用してCharacter.isDigit()
いますが、10進数も削除されます。どうすれば10進数を保持できますか?
回答:
このコードを試してください:
String str = "a12.334tyz.78x";
str = str.replaceAll("[^\\d.]", "");
今str
含まれています"12.334.78"
。
[^\\d.-]
"1233478"
、これは正しくありません。
私は正規表現を使用します。
String text = "-jaskdh2367sd.27askjdfh23";
String digits = text.replaceAll("[^0-9.]", "");
System.out.println(digits);
プリント
2367.2723
-
負の数についても同様に保持することができます。
^
と.
意味について説明してください。
[^
は、これらの文字ではなく、[]
aの中.
は単なるaであることを意味します.
.
は単なるaでa
あり、何も意味しないので、それを取り除くことはできますか?
.
は、結果にs が必要ない場合にのみ使用します。
String phoneNumberstr = "Tel: 00971-557890-999";
String numberRefined = phoneNumberstr.replaceAll("[^\\d-]", "");
結果:0097-557890-999
Stringに "-"も必要ない場合は、次のようにすることができます。
String phoneNumberstr = "Tel: 00971-55 7890 999";
String numberRefined = phoneNumberstr.replaceAll("[^0-9]", "");
結果:0097557890999
グアバと:
String input = "abx123.5";
String result = CharMatcher.inRange('0', '9').or(CharMatcher.is('.')).retainFrom(input);
http://code.google.com/p/guava-libraries/wiki/StringsExplainedを参照してください
str = str.replaceAll("\\D+","");
printf()
が重複していることを示すようなものです。また、コメントに回答が表示された場合は、modに回答に変換するよう依頼するか、独自に回答を追加することもできます。StackOverlowでは、コメントへの回答は推奨されていません。
正規表現を使用しない簡単な方法:
ドットの文字チェックを追加'.'
すると、要件が解決します。
public static String getOnlyNumerics(String str) {
if (str == null) {
return null;
}
StringBuffer strBuff = new StringBuffer();
char c;
for (int i = 0; i < str.length() ; i++) {
c = str.charAt(i);
if (Character.isDigit(c) || c == '.') {
strBuff.append(c);
}
}
return strBuff.toString();
}
これをJava 8ストリームに置き換える方法:
public static void main(String[] args) throws IOException
{
String test = "ab19198zxncvl1308j10923.";
StringBuilder result = new StringBuilder();
test.chars().mapToObj( i-> (char)i ).filter( c -> Character.isDigit(c) || c == '.' ).forEach( c -> result.append(c) );
System.out.println( result ); //returns 19198.130810923.
}
通貨の小数点記号は、ロケールによって異なる場合があります。.
常にセパレータと見なすのは危険な場合があります。すなわち
╔════════════════╦═══════════════════╗
║ Currency ║ Sample ║
╠════════════════╬═══════════════════╣
║ USA ║ $1,222,333.44 USD ║
║ United Kingdom ║ £1.222.333,44 GBP ║
║ European ║ €1.333.333,44 EUR ║
╚════════════════╩═══════════════════╝
私は正しい方法だと思います:
DecimalFormatSymbols
デフォルトのロケールまたは指定されたロケールを介して小数点文字を取得します。そしてここで私はそれをどのように解決していますか:
import java.text.DecimalFormatSymbols;
import java.util.Locale;
コード:
public static String getDigit(String quote, Locale locale) {
char decimalSeparator;
if (locale == null) {
decimalSeparator = new DecimalFormatSymbols().getDecimalSeparator();
} else {
decimalSeparator = new DecimalFormatSymbols(locale).getDecimalSeparator();
}
String regex = "[^0-9" + decimalSeparator + "]";
String valueOnlyDigit = quote.replaceAll(regex, "");
try {
return valueOnlyDigit;
} catch (ArithmeticException | NumberFormatException e) {
Log.e(TAG, "Error in getMoneyAsDecimal", e);
return null;
}
return null;
}
それがお役に立てば幸いです」
これは、null入力、負の数、および10進数を処理します(プロジェクトにApache Commons Langライブラリ、バージョン3.8以降を含める必要があります):
import org.apache.commons.lang3.RegExUtils;
result = RegExUtils.removeAll(input, "-?[^\\d.]");
ライブラリリファレンス:https : //commons.apache.org/proper/commons-lang/apidocs/org/apache/commons/lang3/RegExUtils.html