D. 写一个字符串到文件中去
1. 函数原型
int fputs(char *str,FILE *fp)
2. 功能说明
把由str指出的字符串写入到fp所指的文件中去。
3. 参数说明
str:指出要写到文件中去的字符串。
fp:这是个文件指针,指出字符串要写入其中的文件。
4. 返回值
正常返回: 写入文件的字符个数,即字符串的长度。
非正常返回:返回一个NULL值,此时应当用feof()或ferror()函数来判别是读取到了文件尾,还是发生了错误。例如,要往一个"读打开" 文件中写字符串时,
会发生错误而返回一个NULL值。
5.实例
【例8.4】以下程序将一个文件的内容附加到另一个文件中去。
//程序名:linkfile.c //执行时可用:linkfile filename1 filename2形式的命令行运行,将文件filename2的内容附加在文件filename1之后。 // file linked program. #include <stdio.h> #define SIZE 512 void main(int argc,char *argv[]) { char buffer[SIZE]; FILE *fp1,*fp2; if(argc!=3) { printf("Usage: linkfile filename1 filename2\\n"); return; } // 按追加方式打开argv[1] 所指文件 if((fp1=fopen(argv[1],"a"))==NULL) { printf("The file %s can not be opened.\\n",argv[1]); return; } if((fp2=fopen(argv[2],"r"))==NULL) { printf("The file %s can not be opened.\\n",argv[2]); return; } // 读入一行立即写出,直到文件结束 while(fgets(buffer,SIZE,fp1)!=NULL) printf("%s\\n",buffer); while(fgets(buffer,SIZE,fp2)!=NULL) fputs(buffer,fp1); fclose(fp1); fclose(fp2); if((fp1=fopen(argv[1],"r"))==NULL) { printf("The file %s can not be opened.\\n",argv[1]); return; } while(fgets(buffer,SIZE,fp1)!=NULL) printf("%s\\n",buffer); fclose(fp1); }
E. 往文件中写格式化数据
1.函数原型
int fprintf(FILE *fp,char *format,arg_list)
2.功能说明
将变量表列(arg_list)中的数据,按照format指出的格式,写入由fp指定的文件。fprintf()函数与printf()函数的功能相同,只是printf()函数是将数据写入屏幕文件(stdout)。
3.参数说明
fp:这是个文件指针,指出要将数据写入的文件。
format:这是个指向字符串的字符指针,字符串中含有要写出数据的格式,所以该字符串成为格式串。格式串描述的规则与printf()函数中的格式串相同。
arg_list:是要写入文件的变量表列,各变量之间用逗号分隔。
4.返回值
无。
5. 实例
【8.5】下列程序的执行文件为display.exe,执行时键入命令行:
display [-i][-s] filename
下面的表格列出了命令行参数的含义及其功能:
//存储文件名:save.txt //程序代码如下: // file display program. #include <stdio.h> void main() { char name[10]; int nAge,nClass; long number; FILE *fp; if((fp=fopen("student.txt","w"))==NULL) { printf("The file %s can not be opened.\\n","student.txt"); return; } fscanf(stdin,"%s %d %d %ld",name,&nClass,&nAge,&number); fprintf(fp,"%s %5d %4d %8ld",name,nClass,nAge,number); fclose(fp); if((fp=fopen("student.txt","r"))==NULL) { printf("The file %s can not be opened.\\n","student.txt"); return; } fscanf(fp,"%s %d %d %ld",name,&nClass,&nAge,&number); printf("name nClass nAge number\\n"); fprintf(stdout,"%-10s%-8d%-6d%-8ld\\n",name,nClass,nAge,number); fclose(fp); }
G. 以二进制形式读取文件中的数据
1. 函数原型
int fread(void *buffer,unsigned sife,unsigned count,FILE *fp)
2. 功能说明
从由fp指定的文件中,按二进制形式将sife*count个数据读到由buffer指出的数据区中。
3. 参数说明
buffer:这是一个void型指针,指出要将读入数据存放在其中的存储区首地址。
sife:指出一个数据块的字节数,即一个数据块的大小尺寸。
count:指出一次读入多少个数据块(sife)。
fp:这是个文件指针,指出要从其中读出数据的文件。
4.返回值
正常返回:实际读取数据块的个数,即count。
异常返回:如果文件中剩下的数据块个数少于参数中count指出的个数,或者发生了错误,返回0值。此时可以用feof()和ferror()来判定到底出现了什么
情况。
H. 以二进制形式写数据到文件中去
1. 函数原型
int fwrite(void *buffer,unsigned sife,unsigned count,FILE *fp)
2. 功能说明
按二进制形式,将由buffer指定的数据缓冲区内的sife*count个数据写入由fp指定的文件中去。
3. 参数说明
buffer:这是一个void型指针,指出要将其中数据输出到文件的缓冲区首地址。
sife:指出一个数据块的字节数,即一个数据块的大小尺寸。
count:一次输出多少个数据块(sife)。
fp:这是个文件指针,指出要从其中读出数据的文件。
4.返回值
正常返回:实际输出数据块的个数,即count。
异常返回:返回0值,表示输出结束或发生了错误。
5.实例
【例8.7】
#include <stdio.h> #define SIZE 4 struct worker { int number; char name[20]; int age; }; void main() { struct worker wk; int n; FILE *in,*out; if((in=fopen("file1.txt","rb"))==NULL) { printf("The file %s can not be opened.\\n","file1.txt"); return; } if((out=fopen("file2.txt","wb"))==NULL) { printf("The file %s can not be opened.\\n","file2.txt"); return; } while(fread(&wk,sizeof(struct worker),1,in)==1) fwrite(&wk,sizeof(struct worker),1,out); fclose(in); fclose(out); }
I. 以二进制形式读取一个整数
1. 函数原型
int getw(FILE *fp)
2. 功能说明
从由fp指定的文件中,以二进制形式读取一个整数。
3. 参数说明
fp:是文件指针。
4. 返回值
正常返回:所读取整数的值。
异常返回:返回EOF,即-1。由于读取的整数值有可能是-1,所以必须用feof()或ferror()来判断是到了文件结束,还是出现了一个出错。
5. 实例
【例8.8】
#include <stdio.h> void main(int argc,char *argv[]) { int i,sum=0; FILE *fp; if(argc!=2) { printf("Command error,Usage: readfile filename\\n"); exit(1); } if(!(fp=fopen(argv[1],"rb"))) { printf("The file %s can not be opened.\\n",argv[1]); exit(1); } for(i=1;i<=10;i++) sum+=getw(fp); printf("The sum is %d\\n",sum); fclose(fp); }
J. 以二进制形式存贮一个整数
1.函数原型
int putw(int n,FILE *fp)
2. 功能说明
以二进制形式把由变量n指出的整数值存放到由fp指定的文件中。
3. 参数说明
n:要存入文件的整数。
fp:是文件指针。
4. 返回值
正常返回:所输出的整数值。
异常返回:返回EOF,即-1。由于输出的整数值有可能是-1,所以必须用feof()或ferror()来判断是到了文件结束,还是出现了一个出错。
5. 实例
【例8.9】
#include <stdio.h> void main(int argc,char *argv[]) { int i; FILE *fp; if(argc!=2) { printf("Command error,Usage: writefile filename\\n"); return; } if(!(fp=fopen(argv[1],"wb"))) { printf("The file %s can not be opened.\\n",argv[1]); return; } for(i=1;i<=10;i++) printf("%d\\n", putw(i,fp)); fclose(fp); }
* 文件状态检查
A. 文件结束
(1) 函数原型
int feof(FILE *fp)
(2) 功能说明
该函数用来判断文件是否结束。
(3) 参数说明
fp:文件指针。
(4) 返回值
0:假值,表示文件未结束。
1:真值,表示文件结束。
(5) 实例
【例8.10】
#include <stdio.h> void main(int argc,char *argv[]) { FILE *in,*out; char ch; if(argc!=3) { printf("Usage: copyfile filename1 filename2\\n"); return; } if((in=fopen(argv[1],"rb"))==NULL) { printf("The file %s can not be opened.\\n",argv[1]); return; } if((out=fopen(argv[2],"wb"))==NULL) { printf("The file %s can not be opened.\\n",argv[2]); return; } while(!feof(in)) { ch=fgetc(in); if(ferror(in)) { printf("read error!\\n"); clearerr(in); } else { fputc(ch,out); if(ferror(out)) { printf("write error!\\n"); clearerr(out); } } } fclose(in); fclose(out); }
B. 文件读/写出错
(1) 函数原型
int ferror(FILE *fp)
(2) 功能说明
检查由fp指定的文件在读写时是否出错。
(3) 参数说明
fp:文件指针。
(4) 返回值
0:假值,表示无错误。
1:真值,表示出错。
C. 清除文件错误标志
(1) 函数原型
void clearerr(FILE *fp)
(2) 功能说明
清除由fp指定文件的错误标志。
(3) 参数说明
fp:文件指针。
(4) 返回值
无。
(5) 实例
【例8.12】
#include <stdio.h> void main(int argc,char *argv[]) { FILE *in,*out; char ch; if(argc!=3) { printf("Usage: copyfile filename1 filename2\\n"); return; } if((in=fopen(argv[1],"rb"))==NULL) { printf("The file %s can not be opened.\\n",argv[1]); return; } if((out=fopen(argv[2],"wb"))==NULL) { printf("The file %s can not be opened.\\n",argv[2]); return; } while(!feof(in)) { ch=fgetc(in); if(ferror(in)) { printf("read error!\\n"); clearerr(in); } else { fputc(ch,out); if(ferror(out)) { printf("write error!\\n"); clearerr(out); } } } fclose(in); fclose(out); }
D. 了解文件指针的当前位置
(1) 函数原型
long ftell(FILE *fp)
(2) 功能说明
取得由fp指定文件的当前读/写位置,该位置值用相对于文件开头的位移量来表示。
(3) 参数说明
fp:文件指针。
(4) 返回值
正常返回:位移量(这是个长整数)。
异常返回:-1,表示出错。
(5) 实例
* 文件定位
A. 反绕
(1) 函数原型
void rewind(FILE *fp)
(2) 功能说明
使由文件指针fp指定的文件的位置指针重新指向文件的开头位置。
(3) 参数说明
fp:文件指针。
(4) 返回值
无。
(5) 实例
【例8.14】
#include <stdio.h> void main() { FILE *in,*out; in=fopen("filename1","r"); out=fopen("filename2","w"); while(!feof(in)) fputc(fgetc(in),out); rewind(out); while(!feof(in)) putchar(fgetc(in)); fclose(in); fclose(out); }
B. 随机定位
(1) 函数原型
int fseek(FILE *fp,long offset,int base)
(2) 功能说明
使文件指针fp移到基于base的相对位置offset处。
(3)参数说明
fp:文件指针。
offset:相对base的字节位移量。这是个长整数,用以支持大于64KB的文件。
base:文件位置指针移动的基准位置,是计算文件位置指针位移的基点。ANSI C定义了base的可能取值,以及这些取值的符号常量。
(4)返回值
正常返回:当前指针位置。
异常返回:-1,表示定位操作出错。
(5)实例
【例8.15】
#include <stdio.h> #include <string.h> struct std_type { int num; char name[20]; int age; char class; }stud; int cstufile() { int i; FILE *fp; if((fp=fopen("stufile","wb"))==NULL) { printf("The file can\'t be opened for write.\\n"); return 0; } for(i=1;i<=100;i++) { stud.num=i; strcpy(stud.name,"aaaa"); stud.age=17; stud.class=\'8\'; fwrite(&stud,sizeof(struct std_type),1,fp); } fclose(fp); return 1; } void main() { int n; FILE *fp; if(cstufile()==0) return; if((fp=fopen("stufile","rb"))==NULL) { printf("The file can not be opened.\\n"); return; } for(n=0;n<100;n+=2) { fseek(fp,n*sizeof(struct std_type),SEEK_SET); fread(&stud,sizeof(struct std_type),1,fp); printf("%10d%20s%10d%4c\\n",stud.num,stud.name,stud.age,stud.class); } fclose(fp); }
* 关于exit()函数
1. 函数原型
void exit(int status)
2. 功能说明
exit()函数使程序立即终止执行,同时将缓冲区中剩余的数据输出并关闭所有已经打开的文件。
3. 参数说明
status:为0值表示程序正常终止,为非0值表示一个定义错误。
4. 返回值
无。
* 关于feof()函数
1. 函数原型
int feof(FILE *fp)
2. 功能说明
在文本文件(ASCII文件)中可以用值为-1的符号常量EOF来作为文件的结束符。但是在二进制文件中-1往往可能是一个有意义的数据,因此不能用它 来作为文件的结束标志。为了能有效判别文件是否结束,ANSI C提供了标准函数feof(),用来识别文件是否结束。
3. 参数说明
fp:文件指针。
4. 返回值
返回为非0值:已到文件尾。
返回为0值:表示还未到文件尾。