who*_*oah 53 c# string double type-conversion
我有一个长字符串,其中双键值由#
- value1#value2#value3#
等分隔
我将它拆分为字符串表.然后,我想将此表中的每个元素转换为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
}
Run Code Online (Sandbox Code Playgroud)
Zbi*_*iew 143
有3个问题.
1)小数分隔符不正确
不同的文化使用不同的小数分隔符(即,
和.
).
如果您要更换.
与,
它应该按预期工作:
Console.WriteLine(Convert.ToDouble("52,8725945"));
Run Code Online (Sandbox Code Playgroud)
您可以使用重载方法解析您的双打,该方法将culture作为第二个参数.在这种情况下,您可以使用InvariantCulture
(什么是不变文化),例如使用double.Parse
:
double.Parse("52.8725945", System.Globalization.CultureInfo.InvariantCulture);
Run Code Online (Sandbox Code Playgroud)
您还应该看一下double.TryParse
,您可以将它与许多选项一起使用,特别有用的是检查您的字符串是否有效double
.
2)你的双重不正确
您的一个值不正确,因为它包含两个点:
15.5859949000000662452.23862099999999
3)您的数组末尾有一个空值,这是一个不正确的双精度值
您可以使用重载Split
删除空值:
string[] someArray = a.Split(new char[] { '#' }, StringSplitOptions.RemoveEmptyEntries);
将类添加为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;
}
}
}
Run Code Online (Sandbox Code Playgroud)
然后调用函数
double DirectExpense = Common.ConvertToDouble(dr["DrAmount"].ToString());
Run Code Online (Sandbox Code Playgroud)
大多数人已经试图回答你的问题.
如果您仍在调试,请考虑使用:
Double.TryParse(String, Double);
Run Code Online (Sandbox Code Playgroud)
这将帮助您在进行实际解析之前首先确定每个字符串中的错误.
如果您遇到与文化相关的问题,可以考虑使用:
Double.TryParse(String, NumberStyles, IFormatProvider, Double);
Run Code Online (Sandbox Code Playgroud)
这个http://msdn.microsoft.com/en-us/library/system.double.tryparse.aspx有一个很好的例子来说明如何使用它们.
如果你需要一个长的,Int64.TryParse也可用:http://msdn.microsoft.com/en-us/library/system.int64.tryparse.aspx
希望有所帮助.
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;
}
Run Code Online (Sandbox Code Playgroud)
并成功通过的测试是:
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);
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
293011 次 |
最近记录: |