我有一段代码,应该从输入文件中读取文本并将其放入结构中。
void load(FILE *fin, struct camion payload[]){
int i=0;
char except;
char buf[1000];
while (fgets(buf,sizeof(buf),fin)){
except='A';
sscanf(buf,"%i-%i-%i %i %s %c",&payload[i].day,&payload[i]. month,&payload[i].year,&payload[i].nparcels,payload[i].origin,&except);
if (except=='E')
payload[i].except=1;
i++;
}
}
fgets正常工作(测试过),但是fscanf从这个文件开始:
01-01-2013 354 hub_J
01-01-2013 109 hub_L
03-01-2013 129 hub_J
04-01-2013 265 hub_J
08-01-2013 488 hub_B
09-01-2013 127 hub_J
09-01-2013 136 hub_K
09-01-2013 97 hub_D
10-01-2013 369 hub_O
11-01-2013 455 hub_G
12-01-2013 125 hub_I E
13-01-2013 105 hub_O
13-01-2013 468 hub_C
13-01-2013 360 hub_H E
返回(打印功能不是问题所在,问题发生在执行sscanf时)如下:
1- 1-2013 354 hub_J
1- 1-2013 109 hub_L
3- 1-2013 129 hub_J
4- 1-2013 265 hub_J
0- 0- 0 0
0- 0- 0 0
0- 0- 0 0
0- 0- 0 0
10- 1-2013 369 hub_O
11- 1-2013 455 hub_G
12- 1-2013 125 hub_I E
13- 1-2013 105 hub_O
13- 1-2013 468 hub_C
13- 1-2013 360 hub_H E
具有E的行表示负载过大,因此E并不总是存在,但这不应该是错误的。
我的头撞在墙上了。
提前谢谢
最佳答案
扫描%i
和前导零的值假定为八进制。08
和09
不是八进制值。使用%d
代替,因为前导零被忽略,值以10为基数。
你可以试试这个。它将扫描所有行中的五个项目。%n
说明符将为您提供扫描处理的字符。然后可以测试buf[offset]
。如果有换行符,则处理整个字符串。否则字符串会有更多内容,第二个sscanf可以捕获剩余的字符。
免责声明:我没有编译和测试这段代码。
void load(FILE *fin, struct camion payload[]){
int i=0;
int offset=0;
char except;
char buf[1000];
while (fgets(buf,sizeof(buf),fin)){
except='A';
if ( ( sscanf(buf,"%d-%d-%d %d %s%n"
,&payload[i].day
,&payload[i].month
,&payload[i].year
,&payload[i].nparcels
,payload[i].origin
,&offset)) == 5) {
if ( buf[offset] != '\n') {
sscanf(buf+offset, " %c", &except);
}
}
if (except=='E') {
payload[i].except=1;
}
i++;
}
}
关于c - C sscanf(fscanf)行与行的行为不同,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/30406319/