文件的打开fopen()
文件的打开操作表示将给用户指定的文件在内存分配一个FILE结构区,并将该结构的指针返回给用户程序,以后用户程序就可用此FILE指针来实现对指定文件的存取操作了。当使用打开函数时,必须给出文件名、文件操作方式(读、写或读写),如果该文件名不存在,就意味着建立(只对写文件而言,对读文件则出错),并将文件指针指向文件开头。若已有一个同名文件存在,则删除该文件,若无同名文件,则建立该文件,并将文件指针指向文件开头。
函数原型:fopen(char *filename,char *type);
其中*filename是要打开文件的文件名指针,一般用双引号括起来的文件名表示,也可使用双反斜杠隔开的路径名。而*type参数表示了对打开文件的操作方式。其可采用的操作方式如下:
方式 含义
“r” 打开,只读
“w” 打开,文件指针指到头,只写
“a” 打开,指向文件尾,在已存在文件中追加
“rb” 打开一个二进制文件,只读
“wb” 打开一个二进制文件,只写
“ab” 打开一个二进制文件,进行追加
“r+” 以读/写方式打开一个已存在的文件
“w+” 以读/写方式建立一个新的文本文件
“a+” 以读/写方式打开一个文件文件进行追加
“rb+” 以读/写方式打开一个二进制文件
“wb+” 以读/写方式建立一个新的二进制文件
“ab+” 以读/写方式打开一个二进制文件进行追加
当用fopen(0成功的打开一个文件时,该函数将返回一个FILE指针,如果文件打开失败,将返回一个NULL指针。
FILE结构区:
文件关闭函数fclose()
文件操作完成后,必须要用fclose()函数进行关闭,这是因为对打开的文件进行写入时,若文件缓冲区的空间未被写入的内容填满,这些内容不会写到打开的文件中去而丢失。只有对打开的文件进行关闭操作时,停留在文件缓冲区的内容才能写到该文件中去,从而使文件完整。再者一旦关闭了文件,该文件对应的FILE结构将被释放,从而使关闭的文件得到保护,因为这时对该文件的存取操作将不会进行。文件的关闭也意味着释放了该文件的缓冲区。
函数原型:int fclose(FILE *stream);
它表示该函数将关闭FILE指针对应的文件,并返回一个整数值。若成功地关闭了文件,则返回一个0值,否则返回一个非0值。
文件读写
1、按照字符读写文件
void f_putc()
{
int i = 0;
FILE *fp = NULL;
//自定义文件路径
char *filename2 = "c:/2.txt";
char a[27]= "abcdefghijklmn";
fp = fopen(filename2, "r+");
if (fp == NULL)
{
printf("func fopen() err:%d \n");
return;
}
printf("打开成功\n");
for (i=0; i<strlen(a); i++)
{
//一个一个字符写入文件
fputc(a[i], fp);
}
fclose(fp);
return ;
}
void f_getc()
{
int i = 0;
FILE *fp = NULL;
char *filename2 = "c:/2.txt";
char a[27]= "abcdefghijklmn";
fp = fopen(filename2, "r+");
if (fp == NULL)
{
printf("func fopen() err:%d \n");
return;
}
printf("打开成功\n");
//如果文件没有到EOF结束
while (!feof(fp))
{
//一个一个字符的读
char tempc = fgetc(fp);
printf("%c", tempc);
}
if (fp != NULL)
{
fclose(fp);
}
return ;
}
void main()
{
f_putc();
f_getc();
system("pause");
return ;
}
2、按照行读写文件
void main21_fputs()
{
int i = 0;
FILE *fp = NULL;
char *filename2 = "c:/22.txt";
char a[27]= "abcdefghijklmn";
fp = fopen(filename2, "w+");
if (fp == NULL)
{
printf("func fopen() err:%d \n");
return;
}
printf("打开成功\n");
//直接向文件中一行字符串
fputs(a, fp);
fclose(fp);
return ;
}
void f_gets()
{
int i = 0;
FILE *fp = NULL;
char *filename2 = "c:/22.txt";
char buf[1024];
fp = fopen(filename2, "r+"); //读和写方式
if (fp == NULL)
{
printf("func fopen() err:%d \n");
return;
}
printf("打开成功\n");
while (!feof(fp))
{
//函数原型:_Check_return_opt_ _CRTIMP char * __cdecl fgets(_Out_z_cap_(_MaxCount) char * _Buf, _In_ int _MaxCount, _Inout_ FILE * _File);
char *p = fgets(buf, 1024, fp);
//1 //C 函数库 会 一行一行的copy数据 到buf指针所指的内存空间中 并且变成C风格的字符串
//2 把\n也copy到buf中
if (p == NULL)
{
goto End;
}
printf("%s", buf);
}
End:
if (fp != NULL)
{
fclose(fp);
}
return ;
}
void main()
{
f_puts();
f_gets();
printf("hello...\n");
system("pause");
return ;
}
3、按照块读写文件
typedef struct Teacher
{
char name[64];
int age ;
}Teacher;
void f_write()
{
int i = 0;
FILE *fp = NULL;
char *fileName = "c:/3.data";
Teacher tArray[3];
int myN = 0;
for (i=0; i<3; i++)
{
sprintf(tArray[i].name, "%d%d%d", i+1, i+1, i+1);
tArray[i].age = i + 31;
}
fp = fopen(fileName, "wb");
if (fp == NULL)
{
printf("建立文件失败\n");
return ;
}
for (i=0; i<3; i++)
{
//_Check_return_opt_ _CRTIMP size_t __cdecl
// fwrite(_In_count_x_(_Size*_Count) const void * _Str, _In_ size_t _Size, _In_ size_t _Count, _Inout_ FILE * _File);
//函数参数
//_Str : 从内存块的开始
//_Size :写入多大的内存
//_Count 写多少次
//_File : 写入到 文件指针 所指向的文件中
//函数的返回值:返成功写入的次数
myN = fwrite( &tArray[i],sizeof(Teacher) , 1, fp);
}
if (fp != NULL)
{
fclose(fp);
}
}
void f_read()
{
int i = 0;
FILE *fp = NULL;
char *fileName = "c:/3.data";
Teacher tArray[3];
int myN = 0;
fp = fopen(fileName, "r+b");
if (fp == NULL)
{
printf("建立文件失败\n");
return ;
}
for (i=0; i<3; i++)
{
//_Check_return_opt_ _CRTIMP size_t __cdecl
// fread(_Out_bytecap_x_(_ElementSize*_Count) void * _DstBuf, _In_ size_t _ElementSize, _In_ size_t _Count, _Inout_ FILE * _File);
myN = fread(&tArray[i], sizeof(Teacher), 1, fp);
//函数的返回值
}
for (i=0; i<3; i++)
{
printf("name:%s, age:%d \n", tArray[i].name, tArray[i].age);
}
if (fp != NULL)
{
fclose(fp);
}
}
void main()
{
f_write();
f_read();
printf("hello...\n");
system("pause");
return ;
}