使用fscanf读取文件

时间:2014-01-25 21:06:29

标签: c file scanf

我的程序有点问题。 它应该读取包含“i”的第一行文件,然后打印出“i”列。 我不知道如何“修复”它

char czytaj(const char *fname)
{
FILE *fh = fopen(fname,"r"); 
int i;
char tabelka[100][100];
int k=0;
int w=0;
if(fh == NULL)
{
    printf("cos zjebales\n");
    return 0;
}

fscanf(fh,"%d",&i); 
printf("%d\n", i);
//while(!feof(fh))
//while(k<5)
{
fscanf(fh,"%s",&tabelka[k][w]);
if(tabelka[k][w]=='\n')
{
    w=w+1;
    k=0;
}
else
{   
    k=k+1;
}
}


fclose(fh);
}

这是文件

3 \n
Kol01 Kol02 Kol03 Kol04 \n
aa 10 11 31 \n
bb 20 21 32 \n
cc 30 31 33 \n
dd 40 41 43 \n

:)

2 个答案:

答案 0 :(得分:0)

fscanf不是该任务的正确例程。它跨行读取非空格*的标记,即它像任何其他空格一样处理行的结尾。

对于分隔列的任务,请使用fgets更好地阅读每一行,然后使用strtok拆分字符串,直到找到所需的列。您不需要整个表的空间,逐行处理行,只为当前行使用一个合理大小的char缓冲区。

*)暂时忽略%[...]说明符。

答案 1 :(得分:0)

int czytaj(const char *fname){
    FILE *fh = fopen(fname, "r"); 
    int col, row;
    int i, ch;
    char tabelka[100][100];

    if(fh == NULL){
        printf("cos zjebales\n");
        return 0;
    }

    fscanf(fh,"%d", &col); 
    printf("%d\n", col);
    --col;//to 0 orign from 1 origin

    for(row = 0;EOF!=(ch = getc(fh));++row){
        ungetc(ch, fh);
        for(i=0;i<col;++i)
            fscanf(fh, " %*s");//skip col-1 column

        fscanf(fh, " %s", tabelka[row]);
        printf("%s\n", tabelka[row]);
        while('\n' != (ch = getc(fh)) && EOF != ch)
            ;
    }
    fclose(fh);
    return 1;
}