1

非負のdoubleまたは整数の位置を示す文字列と整数を取り、Numberまたはnullを返す関数が必要です。'+'がある場合は、nullを返します。

2.1      , 0 -> 2.1
+2.1     , 0 -> null
-1       , 0 -> null
-1.2     , 1 -> 1.2
qwa56sdf , 3 -> 56

これを行うための最もエレガントな方法は何ですか?ありがとう。

updこのようなコードが必要ですが、もっと良いです)

    Number parse(String str, int pos){
        Matcher m = Pattern.compile("^(\\d+(?:\\.\\d+)?)").matcher(str);
        m.region(pos, str.length());
        if(m.find()){
            return Double.parseDouble(m.group());
        } else {
            return null;
        }
    }
4

6 に答える 6

3

あなたは試すことができます:

public static void main(String[] args) {
  System.out.println(parse("2.1", 0));
  System.out.println(parse("+2.1", 0));
  System.out.println(parse("-1", 0));
  System.out.println(parse("-1.2", 1));
  System.out.println(parse("qwa56sdf", 3));
}

private static Double parse(String string, int index) {
  if (string.charAt(index) == '-' || string.charAt(index) == '+') {
    return null;
  }
  try {
    return Double.parseDouble(string.substring(index).replaceAll("[^\\d.]", ""));
  }
  catch (NumberFormatException e) {
    return null;
  }
}

末尾の数字以外の文字をすべて置換して削除する必要がありました。これは、NumberFormatExceptionが発生し、最後の例のような入力に対してnullが返されるためです。

編集:コメントのような場合に機能する他のオプションは、各文字をチェックすることかもしれません

private static Double parse(String string, int index) {
    String finalString = "";
    boolean foundSeparator = false;
    for (char c : string.substring(index).toCharArray()) {
        if (c == '.') {
            if (foundSeparator) {
                break;
            }
            else {
                foundSeparator = true;
            }
        }
        else if (!Character.isDigit(c)) {
            break;
        }
        finalString += c;
    }
    if (finalString == "") {
        return null;
    }
    return Double.parseDouble(finalString);
}
于 2010-08-30T14:40:13.303 に答える
2

String.substring()文字列内の指定された位置から開始するメソッドとNumberFormat、数値を解析するクラスを組み合わせて使用​​する必要があります。

于 2010-08-30T14:41:09.427 に答える
1

Scannerクラスもあります。これには、たとえば、などのプリミティブを読み取るためのメソッドが具体的にscanner.hasNextDouble()ありscanner.nextDouble()ます。+または-のチェックを行う必要があります。これは、チェックに合格するためです。

于 2010-08-30T15:10:42.133 に答える
1

次の実装は、一連の要件に対してより洗練されていると思います。解析にjava.text.NumberFormatクラスを使用しています。

    private static Number parse(String text, int position){
        Number value=null;
        NumberFormat nf = NumberFormat.getInstance();
        try {
            value = nf.parse(text,new ParsePosition(position));
            if (value.intValue() < 0)
                value = null;
        } catch (Exception e) {
            value = null;
        }
        return value;
   }
于 2011-11-27T17:27:20.190 に答える
1
public static Double parseDouble(String input, int fromIndex) {
    Matcher matcher = Pattern.compile("\\d*\\.?\\d+")
        .matcher(input.substring(fromIndex));
    return matcher.lookingAt() ? Double.parseDouble(matcher.group()) : null;
}
于 2010-08-30T15:17:35.507 に答える
1

それが機能的に正しければ、それは私には十分エレガントに見えます。コンパイルする必要があるのは1回だけなので、Patternを最終クラスメンバーにすることをお勧めします。そして、この地域はおそらく必要ありません:

Matcher m = pattern.matcher(str.substring(pos));

もう1つのオプションは、1文字の長さの部分文字列から始めて、それが解析されなくなるまでそれを拡張することです。

if ( str.charAt(pos) == '+' || str.charAt(pos) == '-' ) {
    //special cases
    return null;
}
Double val = null;
for ( int i = pos+1; i <= str.length(); i++ ) {
    try {
       val = Double.parseDouble(str.substring(pos, i)) {
    }  catch (NumberFormatException e) {
       break;
    }
}
return val;

少しシンプルですが、パフォーマンスの面でも素朴です。読みにくくなりますが、パフォーマンスが向上する解決策は、文字を1つずつ見るだけで解析する前に、自分でダブルの終わりを見つけることです。

于 2010-08-30T14:50:01.083 に答える