78

#-value1#value2#value3#などで区切られた double 型の値を持つ長い文字列があります。

文字列テーブルに分割しました。次に、このテーブルのすべての要素を double 型に変換したいのですが、エラーが発生します。ここでの型変換の何が問題になっていますか?

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
}
4

6 に答える 6

201

3つの問題があります。

1)小数点の区切り文字が正しくありません

カルチャが異なれば、使用する小数点の区切り文字も異なります(つまり,.)。

交換.すると,、期待どおりに機能するはずです。

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

2番目のパラメーターとしてカルチャを受け取るオーバーロードメソッドを使用して、doubleを解析できます。この場合、次を使用できますInvariantCulture不変カルチャとは何ですか)。例double.Parse

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

また、を確認する必要があります。double.TryParse多くのオプションで使用でき、文字列が有効かどうかを確認するのに特に役立ちますdouble

2)あなたは間違ったダブルを持っています

2つのドットが含まれているため、値の1つが正しくありません。

15.5859949000000662452.23862099999999

3)配列の最後に空の値があります。これは正しくないdoubleです。

Split空の値を削除するオーバーロードを使用できます。

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

于 2012-07-09T16:42:41.317 に答える
10

クラスを 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());
于 2016-03-26T05:13:03.607 に答える
7

ほとんどの人はすでにあなたの質問に答えようとしています。
まだデバッグ中の場合は、次のものを使用することを考えましたか:

Double.TryParse(String, Double);

これは、実際の解析を行う前に、最初に各文字列の何が問題なのかを判断するのに役立ちます。
文化に関連する問題がある場合は、次の使用を検討してください。

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

このhttp://msdn.microsoft.com/en-us/library/system.double.tryparse.aspxには、それらの使用方法に関する非常に良い例があります。

長いものが必要な場合は、Int64.TryParse も利用できます: http://msdn.microsoft.com/en-us/library/system.int64.tryparse.aspx

それが役立つことを願っています。

于 2012-07-09T16:57:07.800 に答える
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);
于 2016-01-22T13:07:45.433 に答える
0

あなたの文字列には、次のように表示されます。15.5859949000000662452.23862099999999これはdoubleではありません(小数点以下2桁です)。おそらく、それは単なる正当な入力エラーですか?

最後Stringが空になるかどうかを把握し、その状況を説明することもできます。

于 2012-07-09T16:41:23.293 に答える