函数名: fscanf
功 能: 从一个流中执行格式化输入,fscanf遇到空格和换行时结束,注意空格时也结束。这与fgets有区别,fgets遇到空格不结束。
用法:
int
fscanf ( FILE
*stream, const
char *format,[argument...]); |
FILE *stream:文件指针;
char *format:格式字符串;
[argument...]:输入列表。
返回值:整型,成功读入的参数的个数;
如果读取到文件结尾,返回EOF(-1)。
今天在用fscanf读取文件中的浮点数,结果一会儿对,一会儿错,找了一下午,才发现自己忽略了fscanf之后,指针的移动问题。
一直以为fscanf会先读入一整串数,再做判断是否符合格式。结果不是这样的,fscanf在遇到不符合格式的地方即停止,指针即停在非法字符的开始处,可能就是一个串的中间。
下面给出例子:
对比结果即可知,当fscanf(fp,"%lf",&buf[cnt]);读到-1.#QNAN000000000e+000这个串时,%lf只读到-1. 此时fp=87;再用%lf,则指针没有移动j=0,fp=87;然后用%s来读,则可读完后面的串#QNAN000000000e+000。。。。。。
返回值:整型,成功读入的参数的个数;
如果读取到文件结尾,返回EOF(-1)。
今天在用fscanf读取文件中的浮点数,结果一会儿对,一会儿错,找了一下午,才发现自己忽略了fscanf之后,指针的移动问题。
一直以为fscanf会先读入一整串数,再做判断是否符合格式。结果不是这样的,fscanf在遇到不符合格式的地方即停止,指针即停在非法字符的开始处,可能就是一个串的中间。
下面给出例子:
start=clock(); while(1){ j=fscanf(fp,"%lf",&buf[cnt]); printf("j=%d fp=%d\n",j,ftell(fp)); if( j==1 ){ cnt++; }else{ //文件尾或非法字符 j=fscanf(fp,"%s",s); printf("j=%d fp=%d\n",j,ftell(fp)); if(j!=1) break; else{ ndcnt++; //printf("%s\t",s); //continue; } } count++; } fclose(fp); end=clock(); printf("文件读取所花时间:%d 毫秒\n",(end-start));
对比结果即可知,当fscanf(fp,"%lf",&buf[cnt]);读到-1.#QNAN000000000e+000这个串时,%lf只读到-1. 此时fp=87;再用%lf,则指针没有移动j=0,fp=87;然后用%s来读,则可读完后面的串#QNAN000000000e+000。。。。。。