我的程序有点问题。 它应该读取包含“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
:)
答案 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;
}