Why double.TryParse(“0.0000”, out doubleValue) returns false ?

后端 未结 9 641
一个人的身影
一个人的身影 2021-02-03 20:38

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

相关标签:
9条回答
  • 2021-02-03 21:05

    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.

    0 讨论(0)
  • 2021-02-03 21:12

    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.

    0 讨论(0)
  • 2021-02-03 21:16

    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
    }
    
    0 讨论(0)
  • 2021-02-03 21:16

    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.

    0 讨论(0)
  • 2021-02-03 21:20

    It works for me:

    double temp = 0;
    Console.WriteLine(double.TryParse("0.0000", out temp));
    Console.ReadLine();
    

    writes True.

    0 讨论(0)
  • 2021-02-03 21:24

    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:

    • Double.TryParse(String, NumberStyles, IFormatProvider, Double)
    • CultureInfo.CreateSpecificCulture(String)
    • IFormatProvider Interface
    • CultureInfo.InvariantCulture Property
    0 讨论(0)
提交回复
热议问题