I am trying to parse string \"0.0000\" with double.TryParse()
but I have no idea why would it return false in this particular example. When I pass integer-like stri
When this method returns, contains the double-precision floating-point number equivalent to the s parameter, if the conversion succeeded, or zero if the conversion failed.
From the MSDN page for this method.
http://msdn.microsoft.com/en-us/library/994c0zb1.aspx
Zero goes in, zero comes out.
It will return false
if the current culture specifies a decimal point separator that is different than the .
character.
When parsing strings representation you need to be aware in what culture they are represented otherwise you'll get unexpected behavior.
In this case you're getting false
, but it could even be worse, for example in the following example if you were expecting to get the number one you would instead get one thousand:
Thread.CurrentThread.CurrentCulture = new CultureInfo("pt-PT");
double d;
Console.WriteLine(double.TryParse("1.000", out d));
Console.WriteLine(d);
This is because in the pt-PT
culture the .
character is used as NumberGroupSeparator
and the ,
character is used as NumberDecimalSeparator
.
If the input you're parsing comes from the user then always parse it using the culture the user is associated. Getting the culture the user is associated is something dependent on the context, for example in a Windows Forms application you would use Thread.CurrentThread.CurrentCulture
when on the UI thread to get it. In a ASP.NET application this may be different.
Almost certainly the problem is that Thread.CurrentCulture
does not use dot as the decimal separator.
If you know that the number will be always formatted with dot as the decimal separator, use this code that utilizes the other overload of double.TryParse
:
style = NumberStyles.Float | NumberStyles.AllowThousands;
culture = CultureInfo.InvariantCulture;
float num;
if (double.TryParse("0.0000", style, culture, out num)) {
// whatever
}
Changing the CultureInfo with TryParse did nothing for me. I had to change the number formats under Control Panel (Change, date, time, or number formats) and changed the Decimal symbol. Than it worked again.
It works for me:
double temp = 0;
Console.WriteLine(double.TryParse("0.0000", out temp));
Console.ReadLine();
writes True
.
it takes the localization settings at runtime into account... perhaps you are running this on a system where .
is not the decimal point but ,
instead...
In your specific case I assume you want a fixed culture regardless of the system you are running on with .
as the decimal point:
double.TryParse("0.0000", NumberStyles.Number, CultureInfo.CreateSpecificCulture ("en-US"), out temp)
OR
double.TryParse("0.0000", NumberStyles.Number,CultureInfo.InvariantCulture, out temp)
Some MSDN reference links: