#include<stdio.h>
typedef struct stuent Stu;
struct stuent
{
char name[20];
int age;
};
Stu S[100];
void InPut(int N); //写入文件,在文件末尾添加
void OutPut(void); //从文件开始一直到末尾,输出文件内容
void destory(void); //清空文件的内容
int xieru_wenjian(Stu A[]); //将文件中所有信息写入文件
void wenjian_duqu(Stu A[],int N); //将数组中所有信息写入文件
int main(void)
{
Stu a[100];
int i,N;
// InPut(4);
// OutPut();
// N = xieru_wenjian(a);
// destory();
// for( i = 0; i < N; i++)
// {
// printf("%s ",a[i].name);
// printf("%d\n",a[i].age);
// }
return 0;
}
void InPut(int N)
{
int i;
FILE *fp;
fp = fopen("D:\\f1.txt","ab"); //打开文件,以二进制,可添加
if(NULL == fp)
printf("Can not open the file\n");
for( i = 0; i < N; i++) //输入信息
{
printf("Input name:\n");
scanf("%s",S[i].name);
getchar();
printf("Input age:\n");
scanf("%d",&S[i].age);
}
fwrite(S,sizeof(Stu),N,fp); //写入文件
fclose(fp); //关闭文件,必须存在,否则会出现很多奇怪的问题
}
void OutPut(void)
{
int i = 0;
Stu a[100];
FILE *fp;
fp = fopen("D:\\f1.txt","rb"); //以二进制,只读打开文件
if(NULL == fp)
printf("Can not open the file\n");
fread(&a[0],sizeof(Stu),1,fp); //这是非常关键的一步,feof 判断文件结尾函数,
while(!feof(fp)) //有个特性,就是当读到文件结尾时,并不会返回1
{ // 只有当读到文件结尾,然后在读下一个时才会返回1
printf("Name is %s ",a[i].name); //如果你直接写在循环里,输出时会多一行乱码
printf("Age is %d\n",a[i++].age);
fread(&a[i],sizeof(Stu),1,fp);
}
fclose(fp);
}
void destory(void) //清空文件内容
{
FILE *fp;
fp = fopen("D:\\f1.txt","wb"); //以这种写的方式打开文件,会把文件长度截为0
fclose(fp); //无需在进行任何操作,即可清空文件
}
int xieru_wenjian(Stu A[])
{
int i = 0;
FILE *fp;
fp = fopen("D:\\f1.txt","rb"); //以特定的方式打开文件
if(NULL == fp)
printf("Can not open the file\n");
fread(&A[0],sizeof(Stu),1,fp);
while(!feof(fp))
{
fread(&A[++i],sizeof(Stu),1,fp); //复制到数组中
}
fclose(fp);
return i; //返回复制的数目
}
void wenjian_duqu(Stu A[],int N)
{
int i;
FILE *fp;
fp = fopen("D:\\f1.txt","ab"); //打开文件,以二进制,可添加
if(NULL == fp)
printf("Can not open the file\n");
fwrite(A,sizeof(Stu),N,fp); //写入文件
fclose(fp); //关闭文件,必须存在,否则会出现很多奇怪的问题
}
typedef struct stuent Stu;
struct stuent
{
char name[20];
int age;
};
Stu S[100];
void InPut(int N); //写入文件,在文件末尾添加
void OutPut(void); //从文件开始一直到末尾,输出文件内容
void destory(void); //清空文件的内容
int xieru_wenjian(Stu A[]); //将文件中所有信息写入文件
void wenjian_duqu(Stu A[],int N); //将数组中所有信息写入文件
int main(void)
{
Stu a[100];
int i,N;
// InPut(4);
// OutPut();
// N = xieru_wenjian(a);
// destory();
// for( i = 0; i < N; i++)
// {
// printf("%s ",a[i].name);
// printf("%d\n",a[i].age);
// }
return 0;
}
void InPut(int N)
{
int i;
FILE *fp;
fp = fopen("D:\\f1.txt","ab"); //打开文件,以二进制,可添加
if(NULL == fp)
printf("Can not open the file\n");
for( i = 0; i < N; i++) //输入信息
{
printf("Input name:\n");
scanf("%s",S[i].name);
getchar();
printf("Input age:\n");
scanf("%d",&S[i].age);
}
fwrite(S,sizeof(Stu),N,fp); //写入文件
fclose(fp); //关闭文件,必须存在,否则会出现很多奇怪的问题
}
void OutPut(void)
{
int i = 0;
Stu a[100];
FILE *fp;
fp = fopen("D:\\f1.txt","rb"); //以二进制,只读打开文件
if(NULL == fp)
printf("Can not open the file\n");
fread(&a[0],sizeof(Stu),1,fp); //这是非常关键的一步,feof 判断文件结尾函数,
while(!feof(fp)) //有个特性,就是当读到文件结尾时,并不会返回1
{ // 只有当读到文件结尾,然后在读下一个时才会返回1
printf("Name is %s ",a[i].name); //如果你直接写在循环里,输出时会多一行乱码
printf("Age is %d\n",a[i++].age);
fread(&a[i],sizeof(Stu),1,fp);
}
fclose(fp);
}
void destory(void) //清空文件内容
{
FILE *fp;
fp = fopen("D:\\f1.txt","wb"); //以这种写的方式打开文件,会把文件长度截为0
fclose(fp); //无需在进行任何操作,即可清空文件
}
int xieru_wenjian(Stu A[])
{
int i = 0;
FILE *fp;
fp = fopen("D:\\f1.txt","rb"); //以特定的方式打开文件
if(NULL == fp)
printf("Can not open the file\n");
fread(&A[0],sizeof(Stu),1,fp);
while(!feof(fp))
{
fread(&A[++i],sizeof(Stu),1,fp); //复制到数组中
}
fclose(fp);
return i; //返回复制的数目
}
void wenjian_duqu(Stu A[],int N)
{
int i;
FILE *fp;
fp = fopen("D:\\f1.txt","ab"); //打开文件,以二进制,可添加
if(NULL == fp)
printf("Can not open the file\n");
fwrite(A,sizeof(Stu),N,fp); //写入文件
fclose(fp); //关闭文件,必须存在,否则会出现很多奇怪的问题
}