如何在C中读取.csv文件

时间:2018-07-06 09:18:47

标签: c file csv

我知道关于此主题还有其他问题,但是我仍然找不到解决问题的方法。

我正在尝试使用fscanf()函数在C语言中读取.csv文件。

如果我使用文本编辑器打开csv文件,则它看起来像这样:

578,2.2212e+05,223,0,243,0,0,0.09,0,0,0,3
633,2.2222e+05,223,0,243,0,0,-0.04,0,0,0,3
688,2.2232e+05,223,0,243,0,0,0.07,0,0,0,3
740,2.2242e+05,223,0,243,0,0,0.04,0,0,0,3
793,2.2252e+05,224,0,244,0,0.01,0.16,0,0,0,3
848,2.2262e+05,223,0,717,0.060985,0.02,0.08,0,0,0,4
902,2.2272e+05,223,0,721,0.084618,0.03,0.24,0,0,0,5
955,2.2282e+05,223,0,730,0.12825,0.05,0.34,0,0,0,4

我刚刚报告了前几行,但其中包含了更多内容。

然后,我使用以下代码读取文件:

FILE* stream = fopen("./filelog.csv", "r");
if(stream == NULL) {      
       printf("\n file opening failed ");      
       return -1 ;   
} 
int values[8];
int count;
for(count = 0; count < 8; count++) {

    int u = fscanf(stream, "%i", &values[count]);
    printf("%i\n", values[count]);
}

我得到的输出如下:

578
32697
0 
0
1
0
4199901
0

我们可以看到只有第一个值被正确读取。如何读取整个文件并将其存储到矩阵中?我在任何地方都找不到任何解决方案。 非常感谢您的提前答复!

1 个答案:

答案 0 :(得分:6)

您的格式字符串%i解析一个整数,但是整数之后的下一个内容是逗号,而您没有对此进行解析。在使用返回值之前,应始终检查返回值,以确保解析成功。

您需要一个与文件的实际内容匹配的格式字符串,例如:

if (fscanf(stream, " %d,%f,%d,%d,%d,%d,%d,%f,%d,%d,%d,%d", ...) == 12)
{
}
...上方代码中的

表示“在此处放置指向12个适当类型的变量的指针”。格式字符串前面的空格旨在帮助“消耗”流中的空格(例如换行符)。