我一直在努力理解 scanf 及其实际工作原理。我有以下文本文件:
this is a test !
25.0 400.0 400.0 0.0 0.0
20.0 200.0 400.0 3.0 4.0
30.0 50 600.0 1 .0 2.0
50.0 400.0 200.0 1 .0 -2.0
40.0 700.0 700.0 -1 .0 -2.0
基本上,代码应该读取每一行并将它们分配给一个单独的数组(数组 A 从第一列获取浮点数,数组 B 从第二列获取浮点数,依此类推)。我唯一能理解的是如何打开文件进行阅读:
FILE *file = fopen( argv[1], "r" );
但我不知道如何从第 1、2、3 和 4 行中提取双精度。顺便说一下,我使用条件语句跳过了第 1 行。我阅读了以下内容:
while (fgets(line, sizeof(line), file))
{
if (count < 1)
{
//printf("%s", line);
count++;
}
else
{
printf("%s", line);
}
}
这些行正在打印,但再次......不知道如何提取每个单独的数字。帮助将不胜感激。
编辑:选择解决方案
这是我在此测试应用程序中使用的代码。正如答案中提到的,文本文件有一些拼写错误,这使得扫描数据变得更加困难,并且需要在运行代码之前对其进行编辑。此外,必须添加“int i = 0”的声明才能在数组上工作。
while (fgets(line, sizeof(line), file))
{
if( 5 == sscanf(line, "%f%f%f%f%f", &A[i], &B[i], &C[i], &D[i], &E[i]) )
{
i++;
}
else
{
printf( "Parse failed\n" );
}
}