文件读写

打开文件

fopen( ) 函数来创建一个新的文件或者打开一个已有的文件

FILE *fopen( const char *filename, const char *mode );

filename 是文件的路径,用来命名文件,访问模式 mode 的值可以是下列值中的一个:

模式 描述
r 打开一个已有的文本文件,允许读取文件。
w 打开一个文本文件,允许写入文件。如果文件不存在,则会创建一个新文件。在这里,您的程序会从文件的开头写入内容。如果文件存在,则该会被截断为零长度,重新写入。
a 打开一个文本文件,以追加模式写入文件。如果文件不存在,则会创建一个新文件。在这里,您的程序会在已有的文件内容中追加内容。
r+ 打开一个文本文件,允许读写文件。
w+ 打开一个文本文件,允许读写文件。如果文件已存在,则文件会被截断为零长度,如果文件不存在,则会创建一个新文件。
a+ 打开一个文本文件,允许读写文件。如果文件不存在,则会创建一个新文件。读取会从文件的开头开始,写入则只能是追加模式。

如果处理的是二进制文件,则需使用下面的访问模式来取代上面的访问模式:

"rb", "wb", "ab", "rb+", "r+b", "wb+", "w+b", "ab+", "a+b"

和python的很像

关闭文件

使用 fclose( ) 函数。函数的原型如下:

int fclose( FILE *fp );

如果成功关闭文件,fclose( ) 函数返回零,如果关闭文件时发生错误,函数返回 EOF。这个函数实际上会清空缓冲区中的数据,关闭文件,并释放用于该文件的所有内存。EOF 是一个定义在头文件 stdio.h 中的常量

模式和指针

不同模式打开文件时指针(游标)的位置不同,可能会影响到读写顺序,尤其在 ‘ + ‘ 模式下

和之间学python类似,c也有fseek来移动光标,详见python文件的补充

写入文件

写文件有三个函数:

int fputc( int c, FILE *fp );

把参数 c 的字符值写入到 fp 所指向的输出流中。如果写入成功,它会返回写入的字符,如果发生错误,则会返回 EOF

int fputs( const char *s, FILE *fp );

把字符串 s 写入到 fp 所指向的输出流中。如果写入成功,它会返回字符串的长度,如果发生错误,则会返回 EOF

 int fprintf(FILE *fp,const char *format, ...)

也是把字符串写入fp指向的输出流,但是可以格式化参数,输出变量或表达式的值

如:

#include<stdio.h>
int main(){
    FILE * fp;
    fp=fopen("./test.txt","w+");
    fputc(98,fp);
    fputs("\nHello\n",fp);
    fprintf(fp,"fp address:%d",fp);
    fclose(fp);
}

读取文件

同样三个函数

int fgetc( FILE * fp );

fp 所指向的输入文件中读取一个字符。返回值是读取的字符,如果发生错误则返回 EOF

char *fgets( char *buf, int n, FILE *fp );

从 fp 所指向的输入流中读取 n – 1 个字符。它会把读取的字符串复制到缓冲区 buf,并在最后追加一个 null 字符来终止字符串。如果这个函数在读取最后一个字符之前就遇到一个换行符 ‘\n’ 或文件的末尾 EOF,则只会返回读取到的字符,包括换行符

还是那个文件:

#include<stdio.h>
int main(){
    FILE * fp;
    char buff[100];
    fp=fopen("./test.txt","r");
    printf("%s",fgets(buff,50,fp));
    fclose(fp);

}

在第一个换行符就停止读取了,继续读取可以用循环

int fscanf(FILE *fp, const char *format, ...)

格式化读取,可以把文件内容分段存在多个字节流中,分隔符为空格或换行,返回参数的个数

#include<stdio.h>
int main(){
    FILE * fp;
    char buff1[20],buff2[20],buff3[20];
    fp=fopen("./test.txt","r");
    printf("%d",fscanf(fp,"%s %s %s",buff1,buff2,buff3));
    printf("\n%s%s%s",buff1,buff2,buff3);
    fclose(fp);
}

二进制IO

二进制存储,直接存二进制位的信息,是直接把本质存储了.可以保证数据完整,无误差,像float型的如1/3,不论保留多少位小数都是有误差的,而用二进制存储可以避免.同时二进制存储,也可以存像数组,结构体或其他自己定义的数据结构

函数原型:

size_t __cdecl fwrite(const void *__restrict__ _Str, size_t _Size, size_t _Count, FILE *__restrict__ _File);
size_t __cdecl fread(void *__restrict__ _DstBuf, size_t _ElementSize, size_t _Count, FILE *__restrict__ _File)

size_t:是int的别名,第一个参数是要写的元素地址和要读入的元素地址,第二个参数size是读写的元素的位数,如果是int型,那size就是4,一般直接用sizeof()表达式表示,第三个参数count是要读写的元素的个数,最后一个参数是FILE对象地址

返回值是读写的元素个数,也就是第三个参数

一般为了读写完整,读写的类型和size都是相同的,个数可以不同.

如:存数组:

#include<stdio.h>
int main(){
    FILE * fp;
    fp=fopen("./test.txt","w+b");
    int arr[5]={3,1,23,41,5};
    int w=fwrite(arr,sizeof(int),5,fp);
    rewind(fp);
    int buff[100];
    int r=fread(buff,sizeof(int),5,fp);
    for(int i=0;i<5;i++)
        printf("%d ",buff[i]);
    fclose(fp);
    printf("\n%d\n%d",w,r);
}

存结构体:

#include<stdio.h>
typedef struct{
    int a;
    int b;
}student;
int main(){
    student s1,s2;
    s1.a=27;
    s1.b=56;
    FILE * fp;
    fp=fopen("./test.txt","w+b");
    fwrite(&s1,sizeof(student),1,fp);
    rewind(fp);
    fread(&s2,sizeof(student),1,fp);
    printf("%d\n%d",s2.a,s2.b);
    fclose(fp);
}

原文地址:http://www.cnblogs.com/Tenerome/p/Creview11.html

1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长! 2. 分享目的仅供大家学习和交流,请务用于商业用途! 3. 如果你也有好源码或者教程,可以到用户中心发布,分享有积分奖励和额外收入! 4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解! 5. 如有链接无法下载、失效或广告,请联系管理员处理! 6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需! 7. 如遇到加密压缩包,默认解压密码为"gltf",如遇到无法解压的请联系管理员! 8. 因为资源和程序源码均为可复制品,所以不支持任何理由的退款兑现,请斟酌后支付下载 声明:如果标题没有注明"已测试"或者"测试可用"等字样的资源源码均未经过站长测试.特别注意没有标注的源码不保证任何可用性