문자열이 double로 구문 분석 가능한지 확인하는 방법은 무엇입니까?
이 질문에 이미 답변이 있습니다.
- 문자열에 포함 된 값이 두 배인지 아닌지 확인하는 방법 13 개의 답변
문자열을 구문 분석 할 수 있는지 확인하는 기본 방법 (자신의 메서드를 구현하지 않는 것이 바람직 함)이 Double.parseDouble()
있습니까?
일반적인 접근 방식은 Double.valueOf(String)
문서 내에서 제안 된 것과 같은 정규 표현식으로 확인하는 것입니다 .
거기에 제공된 (또는 아래에 포함 된) 정규식은 모든 유효한 부동 소수점 경우를 포함해야하므로 결국 일부 미세한 점을 놓칠 수 있으므로 조작 할 필요가 없습니다.
그렇게하고 싶지 않다면 try catch
여전히 옵션입니다.
JavaDoc에서 제안하는 정규식은 다음과 같습니다.
final String Digits = "(\\p{Digit}+)";
final String HexDigits = "(\\p{XDigit}+)";
// an exponent is 'e' or 'E' followed by an optionally
// signed decimal integer.
final String Exp = "[eE][+-]?"+Digits;
final String fpRegex =
("[\\x00-\\x20]*"+ // Optional leading "whitespace"
"[+-]?(" + // Optional sign character
"NaN|" + // "NaN" string
"Infinity|" + // "Infinity" string
// A decimal floating-point string representing a finite positive
// number without a leading sign has at most five basic pieces:
// Digits . Digits ExponentPart FloatTypeSuffix
//
// Since this method allows integer-only strings as input
// in addition to strings of floating-point literals, the
// two sub-patterns below are simplifications of the grammar
// productions from the Java Language Specification, 2nd
// edition, section 3.10.2.
// Digits ._opt Digits_opt ExponentPart_opt FloatTypeSuffix_opt
"((("+Digits+"(\\.)?("+Digits+"?)("+Exp+")?)|"+
// . Digits ExponentPart_opt FloatTypeSuffix_opt
"(\\.("+Digits+")("+Exp+")?)|"+
// Hexadecimal strings
"((" +
// 0[xX] HexDigits ._opt BinaryExponent FloatTypeSuffix_opt
"(0[xX]" + HexDigits + "(\\.)?)|" +
// 0[xX] HexDigits_opt . HexDigits BinaryExponent FloatTypeSuffix_opt
"(0[xX]" + HexDigits + "?(\\.)" + HexDigits + ")" +
")[pP][+-]?" + Digits + "))" +
"[fFdD]?))" +
"[\\x00-\\x20]*");// Optional trailing "whitespace"
if (Pattern.matches(fpRegex, myString)){
Double.valueOf(myString); // Will not throw NumberFormatException
} else {
// Perform suitable alternative action
}
Apache
, as usual, has a good answer from Apache Commons-Lang
in the form of NumberUtils.isCreatable(String)
.
Handles null
s, no try
/catch
block required.
You can always wrap Double.parseDouble() in a try catch block.
try
{
Double.parseDouble(number);
}
catch(NumberFormatException e)
{
//not a double
}
Something like below should suffice :-
String decimalPattern = "([0-9]*)\\.([0-9]*)";
String number="20.00";
boolean match = Pattern.matches(decimalPattern, number);
System.out.println(match); //if true then decimal else not
Google's Guava library provides a nice helper method to do this: Doubles.tryParse(String)
. You use it like Double.parseDouble
but it returns null
rather than throwing an exception if the string does not parse to a double.
All answers are OK, depending on how academic you want to be. If you wish to follow the Java specifications accurately, use the following:
private static final Pattern DOUBLE_PATTERN = Pattern.compile(
"[\\x00-\\x20]*[+-]?(NaN|Infinity|((((\\p{Digit}+)(\\.)?((\\p{Digit}+)?)" +
"([eE][+-]?(\\p{Digit}+))?)|(\\.((\\p{Digit}+))([eE][+-]?(\\p{Digit}+))?)|" +
"(((0[xX](\\p{XDigit}+)(\\.)?)|(0[xX](\\p{XDigit}+)?(\\.)(\\p{XDigit}+)))" +
"[pP][+-]?(\\p{Digit}+)))[fFdD]?))[\\x00-\\x20]*");
public static boolean isFloat(String s)
{
return DOUBLE_PATTERN.matcher(s).matches();
}
This code is based on the JavaDocs at Double.
참고URL : https://stackoverflow.com/questions/3543729/how-to-check-that-a-string-is-parseable-to-a-double
'Program Tip' 카테고리의 다른 글
PowerShell의 명령 출력에 줄 바꿈을 추가하려면 어떻게해야합니까? (0) | 2020.11.16 |
---|---|
대화 상자 내에서 jQuery 대화 상자를 닫는 방법은 무엇입니까? (0) | 2020.11.16 |
VC2010 C ++-소스 파일 구성 (0) | 2020.11.16 |
Serializable을 사용하여 인 텐트를 통해 데이터 전달 (0) | 2020.11.16 |
3 열 레이아웃 HTML / CSS (0) | 2020.11.16 |