C文件读写函数介绍

来源:互联网 发布:vrsjg用什么软件 编辑:程序博客网 时间:2024/04/30 13:28

1.fopen()

  fopen的原型是:FILE *fopen(const char *filename,const char *mode),fopen实现三个功能:为使用而打开一个流,把一个文件和此流相连接,给此流返回一个FILR指针。

  参数filename指向要打开的文件名,mode表示打开状态的字符串,其取值如下:

  字符串 含义

  “r” 以只读方式打开文件

  “w” 以只写方式打开文件

  “a” 以追加方式打开文件

  “r+” 以读/写方式打开文件,如无文件出错

  “w+” 以读/写方式打开文件,如无文件生成新文件

  一个文件可以以文本模式或二进制模式打开,这两种的区别是:在文本模式中回车被当成一个字符’/n’,而二进制模式认为它是两个字符0x0D,0x0A;如果在文件中读到0x1B,文本模式会认为这是文件结束符,也就是二进制模型不会对文件进行处理,而文本方式会按一定的方式对数据作相应的转换。

  系统默认的是以文本模式打开,可以修改全部变量_fmode的值来修改这个设置,例如_fmode=O_TEXT;就设置默认打开方式为文本模式;而_fmode=O_BINARY;则设置默认打开方式是二进制模式。

  我们也可以在模式字符串中指定打开的模式,如”rb”表示以二进制模式打开只读文件,”w+t”或”wt+”表示以文本模式打开读/写文件。

  此函数返回一个FILE指针,所以申明一个FILE指针后不用初始化,而是用fopen()来返回一个指针并与一个特定的文件相连,如果成败,返回NULL.
  例:
   以下是引用片段:
FILE *fp;
  if(fp=fopen(“123.456”,”wb”))
  puts(“打开文件成功”);
  else
  puts(“打开文件成败”);

2.fclose()

  fclose()的功能就是关闭用fopen()打开的文件,其原型是:int fclose(FILE *fp);如果成功,返回0,失败返回EOF。

  在程序结束时一定要记得关闭打开的文件,不然可能会造成数据丢失的情况,我以前就经常犯这样的错误。

  例:fclose(fp);

3.fputc()

  向流写一个字符,原型是int fputc(int c, FILE *stream); 成功返回这个字符,失败返回EOF。

  例:fputc(’X’,fp);

4.fgetc()
  从流中读一个字符,原型是int fputc(FILE *stream); 成功返回这个字符,失败返回EOF。

  例:char ch1=fgetc(fp);

  1. fseek()

      此函数一般用于二进制模式打开的文件中,功能是定位到流中指定的位置,原型是int fseek(FILE *stream, long offset, int whence);如果成功返回0,参数offset是移动的字符数,whence是移动的基准,取值是:

      符号常量 值 基准位置

      SEEK_SET 0 文件开头

      SEEK_CUR 1 当前读写的位置

      SEEK_END 2 文件尾部

      例:fseek(fp,1234L,SEEK_CUR);//把读写位置从当前位置向后移动1234字节(L后缀表示长整数)

      fseek(fp,0L,2);//把读写位置移动到文件尾

6.fputs()

  写一个字符串到流中,原型int fputs(const char *s, FILE *stream);

  例:fputs(“I Love You”,fp);

7.fgets()

  从流中读一行或指定个字符,原型是char *fgets(char *s, int n, FILE *stream); 从流中读取n-1个字符,除非读完一行,参数s是来接收字符串,如果成功则返回s的指针,否则返回NULL。

  例:如果一个文件的当前位置的文本如下:
  Love ,I Have

  But ……..

  如果用

  fgets(str1,4,file1);

  则执行后str1=”Lov”,读取了4-1=3个字符,而如果用

  fgets(str1,23,file1);

  则执行str=”Love ,I Have”,读取了一行(不包括行尾的’/n’)。

8.fprintf()

  按格式输入到流,其原型是int fprintf(FILE *stream, const char *format[, argument, …]);其用法和printf()相同,不过不是写到控制台,而是写到流罢了。

  例:fprintf(fp,”%2d%s”,4,”Hahaha”);

9.fscanf()

  从流中按格式读取,其原型是int fscanf(FILE *stream, const char *format[, address, …]);其用法和scanf()相同,不过不是从控制台读取,而是从流读取罢了。

  例:fscanf(fp,”%d%d” ,&x,&y);

10.feof()

  检测是否已到文件尾,是返回真,否则返回0,其原型是int feof(FILE *stream);

  例:if(feof(fp))printf(“已到文件尾”);

11.ferror()

  原型是int ferror(FILE *stream);返回流最近的错误代码,可用clearerr()来清除它,clearerr()的原型是void clearerr(FILE *stream);

  例:printf(“%d”,ferror(fp));

12.rewind()

  把当前的读写位置回到文件开始,原型是void rewind(FILE *stream);其实本函数相当于fseek(fp,0L,SEEK_SET);

  例:rewind(fp);

13.remove()

  删除文件,原型是int remove(const char *filename); 参数就是要删除的文件名,成功返回0。

  例:remove(“c://io.sys”);

14.fread()

  从流中读指定个数的字符,原型是size_t fread(void ptr, size_t size, size_t n, FILE *stream);参数ptr是保存读取的数据,void的指针可用任何类型的指针来替换,如char*、int *等等来替换;size是每块的字节数;n是读取的块数,如果成功,返回实际读取的块数(不是字节数),本函数一般用于二进制模式打开的文件中。

  例:
   以下是引用片段:
char x[4230];
  FILE *file1=fopen(“c://msdos.sys”,”r”);
  fread(x,200,12 ,file1);//共读取200*12=2400个字节

15.fwrite()

  与fread对应,向流中写指定的数据,原型是size_t fwrite(const void ptr, size_t size, size_t n, FILE *stream);参数ptr是要写入的数据指针,void的指针可用任何类型的指针来替换,如char*、int *等等来替换;size是每块的字节数;n是要写的块数,如果成功,返回实际写入的块数(不是字节数),本函数一般用于二进制模式打开的文件中。

  例:
   以下是引用片段:
  char x[]=”I Love You”;
  fwire(x, 6,12,fp);//写入6*12=72字节
  将把”I Love”写到流fp中12次,共72字节

16.tmpfile()

  其原型是FILE *tmpfile(void); 生成一个临时文件,以”w+b”的模式打开,并返回这个临时流的指针,如果失败返回NULL。在程序结束时,这个文件会被自动删除。

  例:FILE *fp=tmpfile();

17.tmpnam();

  其原型为char *tmpnam(char *s); 生成一个唯一的文件名,其实tmpfile()就调用了此函数,参数s用来保存得到的文件名,并返回这个指针,如果失败,返回NULL。

  例:tmpnam(str1);

  1. 首先要理解几个概念:

文件: 按一定规则存储在磁盘上的数据集合。

文件名: 能唯一标识某个磁盘文件的字符串。形式: 盘符:/ 路径 / 文件名.扩展名

文本文件:: 数据以其数字字符的ASCII码形式、一个字节一个字节地存储在磁盘上。

二进制文件:数据以二进制形式在存储在磁盘上。

设备文件:输入/输出设备

标准输入文件:键盘

标准输出文件/标准错误输出文件:显示器

文件型指针:C语言是通过名为FILE的结构型指针来管理文件读写的。FILE *<变量名>

文件的打开和关闭 :文件操作先建立文件与文件指针之间的关系,接着进行文件的读与写。建立文件与文件指针之间的联系的过程是文件的打开。终止这种联系就是文件的关闭。

FILE结构:定义在〈stdio.h〉中。形式如下:

typedef struct

{

int _fd; /文件代号/

int _cleft; /* 文件缓冲区所剩字节数*/

int _mode; /* 文件使用模式*/

char nextc; / 下一个等待处理的字节地址, 即文件内部指针*/

char buff; / 文件缓冲区首地址 */

}FILE;

  1. 主要操作函数用相应的使用

1) 文件的打开与关闭:

#include <stdio.h> FILE *fp; fp = fopen(char* filename,  char*  made); if(fp == NULL) { exit(0); } fclose(fp) 

mode和种类有:

r : 打开一个文本文件,供读取数据, 文件不存在,则返回NULL

w : 建立一个供写入的文本文件. 废弃原有内容

a: 打开或建立一个把数据追加到文件尾的文本文件

r+: 更新数据

w+ : 更新数据,废弃原有内容

a+ : 更新数据, 写入的数据追加到文件尾.

二进制在后面加”b”

标准输入/输出文件的文件型指针: stdin, stdout, stderr

2) 文件的读与写:

把一个字符写入文件, 或从文件中读取一个字符: 文件内部指针自动移向下一位可读写的位置

int fputc(char ch, FILE *fp);

int fgetc( FILE *fp)

把一行数据写入文件, 或读取一行数据:

char * fputs(char *str, FILE *fp)

char * fgets(char *str, int n, FILE *fp) ; // 读取N-1 个字符,第N个字符补’/0’

把指定字节数的若干数据写入文件, 或读出文件.

int fwrite(char * buf, unsigned size, unsigned n, FILE *fp); size 每个数据的字节数, n 个数据.

int fread(char *buf, unsigned size, unsigned n, FILE *fp);

把指定格式的数据写入文件, 或读取指定格式的数据

int fprintf(FILE *fp, char *format, e1,e2,……en);

int fscanf(FILE *fp, char *format, e1,e2,……en);

3) 文件位置的确定与指针管理.

文件尾的测试: int feof(FILE *fp); //当前已到达文件尾返回非0, 否则返回0

不同的计算机系统以不同的键盘组合键形成文件的结束符. IBM PC及其兼容机是 + z

把文件内部指针重新定位到文件的起始位置 int rewind(FILE *fp);

把文件内部指针定位到指定的位置: int fseek(FILE *fp, long offset, int from);

from 是定位的起始点.

SEEK_SET 0 从文件头开始

SEEK_CUR 1 从文件内部指针当前位置开始

SEEK_END 2 从文件尾开始

offset 是以From 为起始点的依稀字节数,大于0表示向文件尾方向, 0 不移动,

文件操作出错测式 int ferror(FILE *fp);

用于对由FP指向的文件最近一次操作进行正确性测试. 出错返回非0,还没返回0

4) 文件的删除

int remove(char * filename);

  1. 一些以前我没想到的知识点.

char ch;

ch = getchar () 功能等价于 ch = fgetc(stdin) 功能等价于 scanf(“%c”,ch) 功能等价于 fscanf(stdin, “%c”,ch)

putchar(ch) 功能等价于 printf(“%c”,ch) 功能等价于 fputc(stdout) 功能等价于 fprintf(stdout, “%c”, ch)

18.清除和设置文件缓冲区
(1).清除文件缓冲区函数:
int fflush(FILE *stream);
int flushall();
fflush()函数将清除由stream指向的文件缓冲区里的内容,常用于写完一些数据后,立即用该函数清除缓冲区,以免误操作时,破坏原来的数据。 flushall()将清除所有打开文件所对应的文件缓冲区。
(2).设置文件缓冲区函数
void setbuf(FILE *stream,char *buf);
void setvbuf(FILE *stream,char *buf,int type,unsigned size);
这两个函数将使得打开文件后,用户可建立自己的文件缓冲区,而不使用fopen()函数打开文件设定的默认缓冲区。 对于setbuf()函数,buf指出的缓冲区长度由头文件stdio.h中定义的宏BUFSIZE的值决定,缺省值为512字节。当选定buf为空时,setbuf函数将使的文件I/O不带缓冲。而对setvbuf函数,则由malloc函数来分配缓冲区。参数size指明了缓冲区的长度(必须大于0),而参数type则表示了缓冲的类型,其值可以取如下值: type 值 含义 _IOFBF 文件全部缓冲,即缓冲区装满后,才能对文件读写 _IOLBF 文件行缓冲,即缓冲区接收到一个换行符时,才能对文件读写 _IONBF 文件不缓冲,此时忽略buf,size的值,直接读写文件,不再经过文件缓冲区缓冲。
19.文件的随机读写函数
前面介绍的文件的字符/字符串读写,均是进行文件的顺序读写,即总是从文件的开头开始进行读写。这显然不能满足我们的要求,C语言提供了移动文件指针和随机读写的函数,它们是:
(1).移动文件指针函数:
long ftell(FILE *stream);
int rewind(FILE *stream);
fseek(FILE *stream,long offset,int origin);
函数ftell()用来得到文件指针离文件开头的偏移量。当返回值是-1时表示出错。 rewind()函数用于文件指针移到文件的开头,当移动成功时,返回0,否则返回一个非0值。 fseek()函数用于把文件指针以origin为起点移动offset个字节,其中origin指出的位置可有以下几种:
origin 数值 代表的具体位置
SEEK_SET 0 文件开头
SEEK_CUR 1 文件指针当前位置
SEEK_END 2 文件尾
例如: fseek(fp,10L,0); 把文件指针从文件开头移到第10字节处,由于offset参数要求是长整型数,故其数后带L。
fseek(fp,-15L,2); 把文件指针从文件尾向前移动15字节。
(2).文件随机读写函数
int fread(void *ptr,int size,int nitems,FILE *stream);
int fwrite(void *ptr,int size,int nitems,FILE *stream);
fread()函数从流指针指定的文件中读取nitems个数据项,每个数据项的长度为size个字节,读取的nitems数据项存入由ptr指针指向的内存缓冲区中,在执行fread()函数时,文件指针随着读取的字节数而向后移动,最后移动结束的位置等于实际读出的字节数。该函数执行结束后,将返回实际读出的数据项数,这个数据项数不一定等于设置的nitems,因为若文件中没有足够的数据项,或读中间出错,都会导致返回的数据项数少于设置的nitems。当返回数不等于nitems时,可以用feof()或ferror()函数进行检查。 fwrite()函数从ptr指向的缓冲区中取出长度为size字节的nitems个数据项,写入到流指针stream指向的文件中,执行该操作后,文件指针将向后移动,移动的字节数等于写入文件的字节数目。该函数操作完成后,也将返回写入的数据项数。

0 0