在C#中将字符串转换为双精度


71

我有一个长字符串,带有用#-value1#value2#value3#等分隔的双精度值

我将其拆分为字符串表。然后,我想将此表中的每个单个元素都转换为双精度类型,但出现错误。这里的类型转换有什么问题?

string a = "52.8725945#18.69872650000002#50.9028073#14.971600200000012#51.260062#15.5859949000000662452.23862099999999#19.372202799999250800000045#51.7808372#19.474096499999973#";
string[] someArray = a.Split(new char[] { '#' });
for (int i = 0; i < someArray.Length; i++)
{
    Console.WriteLine(someArray[i]); // correct value
    Convert.ToDouble(someArray[i]); // error
}

5
什么错 它对我来说很好...
Dave Bish 2012年

3
@DaveBish尝试遍历所有它们,您将看到索引5是转换为双精度值的错误字符串。
Stefan H

2
@StefanH:当然,但是索引0似乎不错。

1
您的输入值之一有两个小数位。
马特

查看字符串的字节tablicaLatLng[0],它应该告诉您什么地方不对。
NominSim 2012年

Answers:


176

有3个问题。

1)错误的小数点分隔符

不同的区域性使用不同的十进制分隔符(即,.)。

如果您要更换.,它应该按预期工作:

Console.WriteLine(Convert.ToDouble("52,8725945"));

您可以使用将文化作为第二个参数的重载方法来解析双打。在这种情况下,您可以使用InvariantCulture什么是不变文化),例如,使用double.Parse

double.Parse("52.8725945", System.Globalization.CultureInfo.InvariantCulture);

您还应该看一下double.TryParse,可以将其与许多选项一起使用,这对于检查字符串是否有效特别有用double

2)您有错误的双打

您的值之一不正确,因为它包含两个点:

15.5859949000000662452.23862099999999

3)您的数组结尾处有一个空值,这是不正确的double

您可以使用重载Split来删除空值:

string[] someArray = a.Split(new char[] { '#' }, StringSplitOptions.RemoveEmptyEntries);


1
感谢您的不赞成票和解释。当我将版本更改为工作时,我已经尝试过使用转换版本.并将其提供给我(文化:pl_PL)。这也是他的问题的答案(关于第一个double)。StringFormatException,
Zbigniew 2012年

是的,用替换.可以,正常工作,但我必须使用.而不是使用值,(对于google api-lat和lng需要'。')。
Whoah 2012年

+1好收获。您能告诉@whoah如何“改变文化”进行解析吗?还是解析为不同的文化?
罗布一世

@Robl肯定的事情,它曾经发生在我身上,所以这是我脑海中的第一件事:P
Zbigniew 2012年

1
太好了!这很完美:)你能告诉我,这部分意味着什么?System.Globalization.CultureInfo.InvariantCulture?非常感谢您的帮助,问候!
whoah 2012年

8

将类添加为Public,并像convertToInt32()一样非常容易地使用它

  using System;
  using System.Collections.Generic;
  using System.Linq;
  using System.Web;

  /// <summary>
  /// Summary description for Common
  /// </summary>
  public static class Common
  {
     public static double ConvertToDouble(string Value) {
        if (Value == null) {
           return 0;
        }
        else {
           double OutVal;
           double.TryParse(Value, out OutVal);

           if (double.IsNaN(OutVal) || double.IsInfinity(OutVal)) {
              return 0;
           }
           return OutVal;
        }
     }
  }

然后调用函数

double DirectExpense =  Common.ConvertToDouble(dr["DrAmount"].ToString());

7

大多数人已经尝试回答您的问题。
如果仍在调试,是否考虑过使用:

Double.TryParse(String, Double);

这将有助于您在进行实际分析之前首先确定每个字符串中的错误。
如果您有与文化有关的问题,则可以考虑使用:

Double.TryParse(String, NumberStyles, IFormatProvider, Double);

这个http://msdn.microsoft.com/zh-cn/library/system.double.tryparse.aspx上有一个很好的示例,说明了如何使用它们。

如果需要很长的时间,也可以使用Int64.TryParse:http : //msdn.microsoft.com/zh-cn/library/system.int64.tryparse.aspx

希望能有所帮助。


但是没有名为TryParse的方法。
mrbengi 2014年

4
private double ConvertToDouble(string s)
    {
        char systemSeparator = Thread.CurrentThread.CurrentCulture.NumberFormat.CurrencyDecimalSeparator[0];
        double result = 0;
        try
        {
            if (s != null)
                if (!s.Contains(","))
                    result = double.Parse(s, CultureInfo.InvariantCulture);
                else
                    result = Convert.ToDouble(s.Replace(".", systemSeparator.ToString()).Replace(",", systemSeparator.ToString()));
        }
        catch (Exception e)
        {
            try
            {
                result = Convert.ToDouble(s);
            }
            catch
            {
                try
                {
                    result = Convert.ToDouble(s.Replace(",", ";").Replace(".", ",").Replace(";", "."));
                }
                catch {
                    throw new Exception("Wrong string-to-double format");
                }
            }
        }
        return result;
    }

成功通过测试的是:

        Debug.Assert(ConvertToDouble("1.000.007") == 1000007.00);
        Debug.Assert(ConvertToDouble("1.000.007,00") == 1000007.00);
        Debug.Assert(ConvertToDouble("1.000,07") == 1000.07);
        Debug.Assert(ConvertToDouble("1,000,007") == 1000007.00);
        Debug.Assert(ConvertToDouble("1,000,000.07") == 1000000.07);
        Debug.Assert(ConvertToDouble("1,007") == 1.007);
        Debug.Assert(ConvertToDouble("1.07") == 1.07);
        Debug.Assert(ConvertToDouble("1.007") == 1007.00);
        Debug.Assert(ConvertToDouble("1.000.007E-08") == 0.07);
        Debug.Assert(ConvertToDouble("1,000,007E-08") == 0.07);

0

在您的字符串中,我看到:15.5859949000000662452.23862099999999这不是双精度数(它有两个小数点)。也许这只是合法的输入错误?

您可能还想弄清楚最后一个String是否为空,并说明这种情况。


0

您可以尝试此示例。一个简单的C#progaram将字符串转换为double

class Calculations{

protected double length;
protected double height;
protected double width;

public void get_data(){

this.length = Convert.ToDouble(Console.ReadLine());
this.width  = Convert.ToDouble(Console.ReadLine());
this.height = Convert.ToDouble(Console.ReadLine());

   }
}
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.