我有一个浮点数组,它是一个[] []和一个临时读数数组,它是b []。我有这样的数据:
1 1 6 4 12 5 5 3 4 1 67 3 2 1 2 1 0 0 1 0 0 1 0 0 1
2 2 48 2 60 1 3 2 2 1 22 3 1 1 1 1 0 0 1 0 0 1 0 0 1
1 4 12 4 21 1 4 3 3 1 49 3 1 2 1 1 0 0 1 0 0 1 0 1 0
1 1 42 2 79 1 4 3 4 2 45 3 1 2 1 1 0 0 0 0 0 0 0 0 1
2 1 24 3 49 1 3 3 4 4 53 3 2 2 1 1 1 0 1 0 0 0 0 0 1
1 4 36 2 91 5 3 3 4 4 35 3 1 2 2 1 0 0 1 0 0 0 0 1 0
1 4 24 2 28 3 5 3 4 2 53 3 1 1 1 1 0 0 1 0 0 1 0 0 1
1 2 36 2 69 1 3 3 2 3 35 3 1 1 2 1 0 1 1 0 1 0 0 0 0
1 4 12 2 31 4 4 1 4 1 61 3 1 1 1 1 0 0 1 0 0 1 0 1 0
2 2 30 4 52 1 1 4 2 3 28 3 2 1 1 1 1 0 1 0 0 1 0 0 0
2 2 12 2 13 1 2 2 1 3 25 3 1 1 1 1 1 0 1 0 1 0 0 0 1
2 1 48 2 43 1 2 2 4 2 24 3 1 1 1 1 0 0 1 0 1 0 0 0 1
1 2 12 2 16 1 3 2 1 3 22 3 1 1 2 1 0 0 1 0 0 1 0 0 1
2 1 24 4 12 1 5 3 4 3 60 3 2 1 1 1 1 0 1 0 0 1 0 1 0
我的代码在这里:
for( int i = 0 ; i < linecount ; i++ )
{
string[] b = sr.ReadLine().Split( ' ' );
for( int j = 0 ; j < b.Length ; j++ )
{
a[i,j]= float.Parse( b[ j ]);
}
}
它给了我这个错误:
未处理的类型&#39; System.FormatException&#39;发生在 mscorlib.dll中
其他信息:输入字符串的格式不正确。
互联网上的大部分问题都是关于123124.23234而不是123124,23234,但我的数字是整数。我该怎么做? 谢谢!
答案 0 :(得分:0)
您要解析为float的项目之一不仅仅是一个数字,并且可能包含空格。你可以这样做来弄清楚:
for (int i = 0; i < linecount; i++)
{
string[] b = sr.ReadLine().Split(' ');
for (int j = 0; j < b.Length; j++)
{
try
{
a[i, j] = float.Parse(b[j]);
}
catch (FormatException ex)
{
var notANumber = b[j];
}
}
}
您应该尝试使用:
float.Parse(b[j].Trim()); // Remove spaces and the parse it
如果您确定您可能只有空格而没有其他字符。如果您有其他字符,则需要删除它们或使用Replace
替换它们。更好的是,您应该检查解析是否成功然后将其添加到数组中。
无论如何,你知道现在的问题。
答案 1 :(得分:0)
我们可以使用正则表达式过滤掉任何不是数字的内容,但我确定还有其他替代方案
const string testData = @"1 1 6 4 12 5 5 3 4 1 67 3 2 1 2 1 0 0 1 0 0 1 0 0 1
2 2 48 2 60 1 3 2 2 1 22 3 1 1 1 1 0 0 1 0 0 1 0 0 1
1 4 12 4 21 1 4 3 3 1 49 3 1 2 1 1 0 0 1 0 0 1 0 1 0
1 1 42 2 79 1 4 3 4 2 45 3 1 2 1 1 0 0 0 0 0 0 0 0 1
2 1 24 3 49 1 3 3 4 4 53 3 2 2 1 1 1 0 1 0 0 0 0 0 1
1 4 36 2 91 5 3 3 4 4 35 3 1 2 2 1 0 0 1 0 0 0 0 1 0
1 4 24 2 28 3 5 3 4 2 53 3 1 1 1 1 0 0 1 0 0 1 0 0 1
1 2 36 2 69 1 3 3 2 3 35 3 1 1 2 1 0 1 1 0 1 0 0 0 0
1 4 12 2 31 4 4 1 4 1 61 3 1 1 1 1 0 0 1 0 0 1 0 1 0
2 2 30 4 52 1 1 4 2 3 28 3 2 1 1 1 1 0 1 0 0 1 0 0 0
2 2 12 2 13 1 2 2 1 3 25 3 1 1 1 1 1 0 1 0 1 0 0 0 1
2 1 48 2 43 1 2 2 4 2 24 3 1 1 1 1 0 0 1 0 1 0 0 0 1
1 2 12 2 16 1 3 2 1 3 22 3 1 1 2 1 0 0 1 0 0 1 0 0 1
2 1 24 4 12 1 5 3 4 3 60 3 2 1 1 1 1 0 1 0 0 1 0 1 0";
float[] floatArray = testData.Split(' ')
.Select(s => Regex.Match(s, @"(\d*)").Groups[1].Value)
.Select(Convert.ToSingle)
.ToArray();