C语言文件操作 部分函数整理(收集自互联网)

本文详细介绍了C语言中文件操作的基础知识,包括文件的打开与关闭、读写操作、错误处理及文件定位等核心功能。通过示例代码,深入解析fopen、fclose、fgetc、fputc等函数的使用方法,帮助读者掌握文件操作技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

文件操作

打开文件fopen( )

FILE *fopen(char *pname,char *mode);
fopen ()会返回指向FILE对象的指针
如果为NULL表示打开失败

FILE *fopen(char *pname,char *mode);

pname(字符串)要操作的文件名,可以包括目录信息
mode(字符串)操作的模式

返回值

fopen ()会返回指向FILE对象的指针
如果为NULL表示打开失败

char *pname

pname(字符串)要操作的文件名,可以包括目录信息

如果操作的文件不存在的处理方式:
1.写 模式下会新建文件
2.读 模式下会产生一个错误

char *mode

mode(字符串)操作的模式:
r(表示“read”):文件不存在产生一个错误
w(表示“write”):文件不存在就新建,文件存在内容会清除
a(表示“append”):文件不存在就创建,文件存在内容会保存,并追加内容到文件末尾
+(表示读写都可(非同时))
b(表示以二进制模式操作)

示例

####include <stdio.h>
####include <stdbool.h>
_Bool isReadWriteable( const char *filename )
{
FILE *fp = fopen( filename, “r+” ); // 打开一个文件以用于读写
if ( fp != NULL ) // fopen()是否执行成功
{
fclose(fp); // 成功:关闭文件,没有错误需要处理
return true;
}
else // 失败
return false;
}

关闭文件fclose( )

int fclose( FILE *fp );
关闭文件指针对应的文件
返回0表示成功
EOF表示错误

int fclose( FILE *fp );

关闭文件指针对应的文件
返回0表示成功
EOF表示错误

返回值

返回0表示成功
EOF表示错误

从文件读取一个字符fgetc( )

int fgetc(FILE *fp);
从文件指针fp指向的文件读取字符,
返回读取字符的代码,
非正常返回EOF;

int fgetc(FILE *fp);

返回读取字符的代码,
非正常返回EOF;

返回值

返回读取字符的代码,
非正常返回EOF;

示例

//程序名为:display.c
//执行时可用:display filename1 形式的命令行运行。显示文件filename1中的内容。例如,执行命令行display display.c将在屏幕上显示display的原代码。

//File display program.
#include <stdio.h>
void main(int argc,char *argv[]) //命令行参数
{
int ch;
//定义文件类型指针
FILE *fp;
//判断命令行是否正确
if(argc!=2)
{
printf(“Error format,Usage: display filename1\n”);
return; //键入了错误的命令行,结束程序的执行
}
//按读方式打开由argv[1]指出的文件
if((fp=fopen(argv[1],“r”))==NULL)
{
printf(“The file <%s> can not be opened.\n”,argv[1]);//打开操作不成功
return;//结束程序的执行
}
//成功打开了argv[1]所指文件
ch=fgetc(fp); //从fp所指文件的当前指针位置读取一个字符
while(ch!=EOF) //判断刚读取的字符是否是文件结束符
{
putchar(ch); //若不是结束符,将它输出到屏幕上显示
ch=fgetc(fp); //继续从fp所指文件中读取下一个字符
} //完成将fp所指文件的内容输出到屏幕上显示
fclose(fp); //关闭fp所指文件
}

写一个字符到文件 fputc( )

int fputc(int ch,FILE *fp);
正常返回: 要写入字符的代码
非正常:EOF

int fputc(int ch,FILE *fp);

ch整型(和字符型通用)
fp指向要写入的文件

正常返回: 要写入字符的代码
非正常:EOF

返回值

正常返回: 要写入字符的代码
非正常:EOF

示例

//程序名为:copyfile.c
//执行时可用:copyfile filename1 filename2形式的命令行运行,将文件filename1中的内容复制到文件filename2中去。
//file copy program.
#include <stdio.h>
void main(int argc,char *argv[]) //命令行参数
{
int ch;
FILE *in,*out; //定义in和out两个文件类型指针
if(argc!=3) //判断命令行是否正确
{
printf(“Error in format,Usage: copyfile filename1 filename2\n”);
return; //命令行错,结束程序的执行
}
//按读方式打开由argv[1]指出的文件
if((in=fopen(argv[1],“r”))==NULL)
{
printf(“The file <%s> can not be opened.\n”,argv[1]);
return; //打开失败,结束程序的执行
}
//成功打开了argv[1]所指文件,再
//按写方式打开由argv[2]指出的文件
if((out=fopen(argv[2],“w”))==NULL)
{
printf(“The file %s can not be opened.\n”,argv[2]);
return; //打开失败,结束程序的执行
}
//成功打开了argv[2]所指文件
ch=fgetc(in); //从in所指文件的当前指针位置读取一个字符
while(ch!=EOF) //判断刚读取的字符是否是文件结束符
{
fputc(ch,out); //若不是结束符,将它写入out所指文件
ch=fgetc(in); //继续从in所指文件中读取下一个字符
} //完成将in所指文件的内容写入(复制)到out所指文件中
fclose(in); //关闭in所指文件
fclose(out); //关闭out所指文件
}

往文件中写格式化数据fprintf( )

int fprintf(FILE *fp,char *format,arg_list);
arg_list变量列表(用,逗号隔开)中的数据按照format指定的格式写入fp指向的文件

int fprintf(FILE *fp,char *format,arg_list);

arg_list变量列表中的数据按照format指定的格式写入fp指向的文件

示例

//存储文件名: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);
}

二进制形式从文件中读取数据fread( )

int fread(void *buffer,unsigned sife,unsigned count,FILE *fp);

从由fp指定的文件中,按二进制形式将sife*count个数据读到由buffer指出的数据区中

int fread(void *buffer,unsigned sife,unsigned count,FILE *fp);

从由fp指定的文件中,按二进制形式将sife*count个数据读到由buffer指出的数据区中

void *buffer

buffer:这是一个void型指针,指出要将读入数据存放在其中的存储区首地址。

unsigned sife

sife:指出一个数据块的字节数,即一个数据块的大小尺寸。

unsigned count

count:指出一次读入多少个数据块(sife)。

FILE *fp

fp:这是个文件指针,指出要从其中读出数据的文件。

返回值

正常返回:实际读取数据块的个数,即count。
异常返回:如果文件中剩下的数据块个数少于参数中count指出的个数,或者发生了错误,返回0值。此时可以用feof()和ferror()来判定到底出现了什么
情况。

以二进制形式写数据到文件中去fwrite( )

int fwrite(void *buffer,unsigned sife,unsigned count,FILE *fp);

按二进制形式,将由buffer指定的数据缓冲区内的sife*count个数据写入由fp指定的文件中去。

int fwrite(void *buffer,unsigned sife,unsigned count,FILE *fp);

按二进制形式,将由buffer指定的数据缓冲区内的sife*count个数据写入由fp指定的文件中去。

void *buffer

buffer:这是一个void型指针,指出要将其中数据输出到文件的缓冲区首地址。

unsigned sife

sife:指出一个数据块的字节数,即一个数据块的大小尺寸。

unsigned count

count:一次输出多少个数据块(sife)

FILE *fp

fp:这是个文件指针,指出要从其中读出数据的文件。

返回值

正常返回:实际输出数据块的个数,即count。
异常返回:返回0值,表示输出结束或发生了错误

示例

####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);
}

以二进制形式读取一个整数 getw( )

int getw(FILE *fp);

从由fp指定的文件中,以二进制形式读取一个整数。

int getw(FILE *fp)

从由fp指定的文件中,以二进制形式读取一个整数。

返回值

正常返回:所读取整数的值。
异常返回:返回EOF,即-1。由于读取的整数值有可能是-1,所以必须用feof()或ferror()来判断是到了文件结束,还是出现了一个出错。

示例

####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);
}

以二进制形式存贮一个整数putw( )

int putw(int n,FILE *fp);

以二进制形式把由变量n指出的整数值存放到由fp指定的文件中。

int putw(int n,FILE *fp);

以二进制形式把由变量n指出的整数值存放到由fp指定的文件中。

n:要存入文件的整数。
 fp:是文件指针。

返回值

正常返回:所输出的整数值。
异常返回:返回EOF,即-1。由于输出的整数值有可能是-1,所以必须用feof()或ferror()来判断是到了文件结束,还是出现了一个出错。

示例

####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);

}

文件状态检查

文件结束feof( )

int feof(FILE *fp)

该函数用来判断文件是否结束

int feof(FILE *fp)

该函数用来判断文件是否结束

返回值

0:假值,表示文件未结束。
1:真值,表示文件结束。

示例

#####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);
}

文件读、写出错ferror( )

int ferror(FILE *fp)

检查由fp指定的文件在读写时是否出错。

int ferror(FILE *fp)

检查由fp指定的文件在读写时是否出错。

返回值

0:假值,表示无错误。
1:真值,表示出错

清除文件错误标志clearerr( )

void clearerr(FILE *fp)

清除由fp指定文件的错误标志。

void clearerr(FILE *fp)

清除由fp指定文件的错误标志。

示例

#####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);
}

了解文件指针的当前位置ftell( )

long ftell(FILE *fp)

取得由fp指定文件的当前读/写位置,该位置值用相对于文件开头的位移量来表示。

正常返回:位移量(这是个长整数)。
异常返回:-1,表示出错。

long ftell(FILE *fp)

取得由fp指定文件的当前读/写位置,该位置值用相对于文件开头的位移量来表示。

返回值

正常返回:位移量(这是个长整数)。
异常返回:-1,表示出错。

文件定位

反绕rewind()

void rewind(FILE *fp)

使由文件指针fp指定的文件的位置指针重新指向文件的开头位置。

void rewind(FILE *fp)

使由文件指针fp指定的文件的位置指针重新指向文件的开头位置。

示例

#####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);
}

随机定位fseek()

int fseek(FILE *fp,long offset,int base)

使文件指针fp移到基于base的相对位置offset处。

int fseek(FILE *fp,long offset,int base)

使文件指针fp移到基于base的相对位置offset处。

FILE *fp

fp:文件指针。

long offset

offset:相对base的字节位移量。这是个长整数,用以支持大于64KB的文件。

int base

base:文件位置指针移动的基准位置,是计算文件位置指针位移的基点。ANSI C定义了base的可能取值,以及这些取值的符号常量。

返回值

正常返回:当前指针位置。
异常返回:-1,表示定位操作出错

示例

#####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(“d%20sd%4c\n”,stud.num,stud.name,stud.age,stud.class);
}
fclose(fp);
}

exit()函数

void exit(int status)

exit()函数使程序立即终止执行,同时将缓冲区中剩余的数据输出并关闭所有已经打开的文件。

status:为0值表示程序正常终止,为非0值表示一个定义错误。

void exit(int status)

exit()函数使程序立即终止执行,同时将缓冲区中剩余的数据输出并关闭所有已经打开的文件。

status:为0值表示程序正常终止,为非0值表示一个定义错误。

int status

status:为0值表示程序正常终止,为非0值表示一个定义错误。

feof()函数

int feof(FILE *fp)

在文本文件(ASCII文件)中可以用值为-1的符号常量EOF来作为文件的结束符。但是在二进制文件中-1往往可能是一个有意义的数据,因此不能用它 来作为文件的结束标志。为了能有效判别文件是否结束,ANSI C提供了标准函数feof(),用来识别文件是否结束。

int feof(FILE *fp)

在文本文件(ASCII文件)中可以用值为-1的符号常量EOF来作为文件的结束符。但是在二进制文件中-1往往可能是一个有意义的数据,因此不能用它 来作为文件的结束标志。为了能有效判别文件是否结束,ANSI C提供了标准函数feof(),用来识别文件是否结束。

返回值

返回为非0值:已到文件尾。
返回为0值:表示还未到文件尾

fscanf(文件指针,格式字符串,输入表列)

fscanf(fp,"%d%s",&i,s);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值