C++的File类文件操作

C++的File类文件操作

语言文件系统称为流文件(Stream),正文流(正文文件),二进制流(二进制文件)

缓冲与非缓冲文件
顺序操作文件与随机操作文件
顺序文件:读/写第K个数据块之前必须读/写第1至K-1个数据块;
随机文件:可直接读/写第K个数据块;
正文文件的操作一般是顺序文件;
二进制文件的操作都是随机文件。

一、文件操作的一般过程
定义文件指针 FILE *
打开文件 fopen
对文件进行读写

< type=“text/javascript”> < type=“text/javascript” src=“http://pagead2.googlesyndication.com/pagead/show_ads.js”>

二、系统已定义的与文件操作有关的数据结构全都在stdio.h中

FILE 结构体

FILE *fr,*fp,*fw;

FILE* 指针作为文件句柄,是文件访问的唯一标识,它由fopen函数创建,fopen打开文件成功,则返回一个有效的FILE*指针,否则返回空指针NULL

标准文件指针

FILE *stdin,*stdout,*stderr,
stdin 指键盘输入
stdout 指显示器
stderr 指出错输出设备,也指显示器

这些变量已成功初始化,可直接使用.
三、常用操作函数

fopen

格式:FILE *fopen(文件名字符串,打开方式串)

例:FILE *fr; fr=fopen(“c:\user\abc.txt”,“r”);

字符串操作:

1)“r"或"rt”:正文文件只读方式打开。文件不存在,则打开失败(顺序读)“w"或"wt”:正文文件只写方式打开。若文件不存在,则建立文件;若文件存在,则删除文件内容,重建空文件(顺序写);(截取文件长度为0)

  1. “a"或"at”:正文文件添加方式。文件不存在,则建立文件(顺序添加写)

  2. "r+“或"rt++”:正文文件读写打开,文件不存在,则打开失败(顺序读/写、随机读/写,含改写与添加);

  3. "w+“或"w++”:正文文件读写方式打开,文件不存在,则建立文件;否则截取文件长度为0(顺序读/写,随机读/写,对写入的内容可以读或改写或添加)

  4. ~b:正文文件→二进制文件
    顺序读→顺序/随机读(“rb”)

eg:“r"或"rt"→"rb”
顺序写(“wb”)
顺序添加写(“ab”)
顺…,随…,含…(“rb+”)
顺…,添加(“wb+”)
顺…,添加(“ab+”)

使用fopen时,但凡含r字母的打开方式,一定要加判断,文件是否打开成功,否则程序不会报告错误,会运行下去。

如:FILE *fr;
fr=fopen(“abc.txt”,“r”);
if(fr==NULL){
printf(“File not open!\n”);
return; /或exit(1);/

文件关闭

fclose(FILE *fp)

一般地,fclose(fp)与fopen应配对使用,特别是含有写方式的文件,若不关闭会造成文件数据丢失。

fcloseall(void):关闭当前所有打开的文件。

单字节的输入函数

可适用于二进制与正文文件操作
int fgetc(FILE *fp)
int fputc(char ch.FILE *fp)

fgetc的返回值都是正数(0~255)

文件无可读字节则返回-1(EOF)

正文文件与二进制文件读写的区别:
正文文件读到13 10时,将自动跳过13,读出10并返回;正文文件写入10时,首先自动写入13再写入10.

文件指针与文件指针操作函数

文件指针是文件操作系统数据结构内部的一种数据指针,它用于标注文件当前读写位置,C语言中,文件指针以字节为单位,文件第一个字节位置号为0,若文件长度为N个字节,则最后一个字节的位置号为N-1,长度为N字节的文件有效读写范围为0~N-1。指针位置在此之外进行读/写操作,则失败;读写函数返回-1(EOF);

C语言的文件指针采用long型值;

执行文件读/写操作后,文件指针自动向后移动,指到新的待读/写位置。

文件指针移动函数
rewind(FILE *fp)
文件指针重置为0
fseek(FILE *fp,long off,int pos)
从pos位置开始,移动off个字节。

pos: 0 文件开始
1 文件当前指针位置
2 文件结尾(文件长度为N,则指针位置为N)

例:fseek(fp,0l,0);←→rewind(fp)
fseek(fp,-1L,2); /移动指针到最后一个字节/
fseek(fp,-2L,1); /移动指针到当前位置的前两个位置/
long ftell(FILE *fp)

求当前指针位置

例:求文件长度
fseek(fp,OL,2);
len=ftell(fp);
则len为文件长度

文件指针的特性:

可在“负无穷”到“正无穷”任意移动;
在0~N-1之外进行读操作,则读失败;读失败后,feof函数为真;
从N位置开始写入,则为添加;
从0~N位置之外开始写也可,其行为不必掌握,因为几乎无用;
无论任何方式,刚打开文件时,ftell函数返回值都是0,含a方式的文件,只要一写(第一次写),文件指针自动移动到N位置处。
int feof(FILE *fp)
若文件读失败,则返回非0值,否则返回0值;仅用于读是否到文件尾。
任何fseek操作使feof为假,即使文件指针在0~N-1之外。
正文文件读/写函数
fscanf(fp…)
fprintf(fp…)

其中,…与scanf和printf用法完全相同.
scanf(…)←→fscanf(stdin…)
printf(…)←→fprintf(stdout…)

二进制文件读/写函数,即字节块函数
int fread(char *buf,int size,int count,FILE *fp)
int fwrite(char *buf,int&nbtp;size,int count,FILE *fp)
从文件读出size x count个字节到内存块buf;从内存块buf写入size x count个字节到文件,返回实际读出/写入的字节数。

一、文件中删除第K个记录:拷贝0~K-1,K+1~N条记录到一个临时文件,删除源文件,将源文件改名为源文件。

二、读/改写第K个记录:移动指针到第K个记录,用fread,fwrite改写。

三、添加记录(略)

四、插入记录

复制临时文件
插入到K号记录之前:先将N-1写入N位置,N-2写入N-1,直到K写入K+1位置:用待插入记录改写K位置。(建立时用rb+方式打开)
#include “tdio.h”
void main()
{FILE fp;char ch1,ch2;long pos1,pos2,p;
char fname[81];
printf(“Input C source filename:”);
gets(fname);
fp=fopen(fname,“r+”);
if(!fp){printf("FILE not found .\n); return;
ch1=fgetc(fp);
while(!feof(fp))
{cha2=fgetc(fp);if(feof(fp)) break;
if(ch1==’/’&&ch2==’
’)
{pos1=ftell(fp)-2;
}
if(ch1==’*’&&ch==’/’)
{pos2=ftell(fp)-1;
fseek(fp,pos1,0);
for(p=pos1;p<=pos2;p++) fputc(32,fp);
fseek(fp,OL,1);
}
ch1=ch2;
}
fclose(fp);

转自http://blog.csdn.net/jiahehao/archive/2007/11/02/1862867.aspx

文件的读入读出

  1. fopen()函数
    fopen函数用于打开文件, 其调用格式为:
    FILE *fopen(char *filename, *type);

fopen()函数中第一个形式参数表示文件名, 可以包含路径和文件名两部分。
如:
“B:TEST.DAT”
“C:\TC\TEST.DAT”
如果将路径写成"C:\TC\TEST.DAT"是不正确的, 这一点要特别注意。
第二个形式参数表示打开文件的类型。关于文件类型的规定参见下表。
表 文件操作类型
━━━━━━━━━━━━━━━━━━━━━━━━━━━━
字符 含义
────────────────────────────
“r” 打开文字文件只读
“w” 创建文字文件只写
“a” 增补, 如果文件不存在则创建一个
“r+” 打开一个文字文件读/写
“w+” 创建一个文字文件读/写
“a+” 打开或创建一个文件增补
“b” 二进制文件(可以和上面每一项合用)
“t” 文这文件(默认项)
━━━━━━━━━━━━━━━━━━━━━━━━━━━━
如果要打开一个CCDOS子目录中, 文件名为CLIB的二进制文件, 可写成:
fopen(“c:\ccdos\clib”, “rb”);

如果成功的打开一个文件, fopen()函数返回文件指针, 否则返回空指针
(NULL)。由此可判断文件打开是否成功。

  1. fclose()函数
    fclose()函数用来关闭一个由fopen()函数打开的文件 , 其调用格式为:
    int fclose(FILE *stream);
    该函数返回一个整型数。当文件关闭成功时, 返回0, 否则返回一个非零值。
    可以根据函数的返回值判断文件是否关闭成功。
    例10:
    #iclude<stdio.h>
    main()
    {
    FILE *fp; /定义一个文件指针/
    int i;
    fp=fopen(“CLIB”, “rb”); /打开当前目录名为CLIB的文件只读/
    if(fpNULL) /判断文件是否打开成功/
    puts(“File open error”);/提示打开不成功/
    i=fclose(fp); /关闭打开的文件/
    if(i
    0) /判断文件是否关闭成功/
    printf(“O,K”); /提示关闭成功/
    else
    puts(“File close error”);/提示关闭不成功/
    }
    二、有关文件操作的函数
    本节所讲的文件读写函数均是指顺序读写, 即读写了一条信息后, 指针自动
    加1。下面分别介绍写操作函数和读操作函数。
    1. 文件的顺序写函数
      fprintf()、fputs()和fputc()函数
      函数fprintf()、fputs()和fputc()均为文件的顺序写操作函数, 其调用格
      式如下:
      int fprintf(FILE *stream, char *format, );
      int fputs(char *string, FILE *steam);
      int fputc(int ch, FILE *steam);
      上述三个函数的返回值均为整型量。fprintf() 函数的返回值为实际写入文
      件中的字罕个数(字节数)。如果写错误, 则返回一个负数, fputs()函数返回0时
      表明将string指针所指的字符串写入文件中的操作成功, 返回非0时, 表明写操
      作失败。fputc()函数返回一个向文件所写字符的值, 此时写操作成功, 否则返
      回EOF(文件结束结束其值为-1, 在stdio.h中定义)表示写操作错误。
      fprintf( ) 函数中格式化的规定与printf( ) 函数相同, 所不同的只是
      fprintf()函数是向文件中写入。而printf()是向屏幕输出。
      下面介绍一个例子, 运行后产后一个test.dat的文件。
      例11:
      #include<stdio.h>
      main()
      {
      char *s=“That’s good news”); /定义字符串指针并初始化/
      int i=617; /定义整型变量并初始化/
      FILE *fp; /定义文件指针/
      fp=fopne(“test.dat”, “w”); /建立一个文字文件只写/
      fputs(“Your score of TOEFLis”, fp);/向所建文件写入一串字符/
      fputc(’:’, fp); /向所建文件写冒号:/
      fprintf(fp, “%d\n”, i); /向所建文件写一整型数/
      fprintf(fp, “%s”, s); /向所建文件写一字符串/
      fclose(fp); /关闭文件/
      }
      用DOS的TYPE命令显示TEST.DAT的内容如下所示:
      屏幕显示
      Your score of TOEFL is: 617
      That’s good news
    2. 文件的顺序读操作函数
      fscanf()、fgets()和fgetc()函数
      函数fscanf()、fgets()和fgetc()均为文件的顺序读操作函数, 其调用格式
      如下:
      int fscanf(FILE *stream, char *format, );
      char fgets(char *string, int n, FILE *steam);
      int fgetc(FILE *steam);
      fscanf()函数的用法与scanf()函数相似, 只是它是从文件中读到信息。
      fscanf()函数的返回值为EOF(即-1), 表明读错误, 否则读数据成功。fgets()函
      数从文件中读取至多n-1个字符(n用来指定字符数), 并把它们放入string指向的
      字符串中, 在读入之后自动向字符串未尾加一个空字符, 读成功返回string指针,
      失败返回一个空指针。fgetc()函数返回文件当前位置的一个字符, 读错误时返
      回EOF。
      下面程序读取例11产生的test.dat文件, 并将读出的结果显示在屏幕上。
      例12
      #include<stdio.h>
      main()
      {
      char *s, m[20];
      int i;
      FILE *fp;
      fp=fopen(“test.dat”, “r”); /打开文字文件只读/
      fgets(s, 24, fp); /从文件中读取23个字符/
      printf("%s", s); /输出所读的字符串/
      fscanf(fp, “%d”, &i); /读取整型数/
      printf("%d", i); /输出所读整型数/
      putchar(fgetc(fp)); /读取一个字符同时输出/
      fgets(m, 17, fp); /读取16个字符/
      puts(m); /输出所读字符串/
      fclose(fp); /关闭文件/
      getch(); /等待任一键/
      }
      运行后屏幕显示:
      Your score of TOEFL is: 617
      That’s good news
      如果将上例中fscanf(fp, “%d”, &i)改为fscanf(fp, “%s”, m), 再将其后
      的输出语句改为printf("%s", m), 则可得出同样的结果。由此可见Turbo C2. 0
      中只要是读文字文件, 则不论是字符还是数字都将按其ASCII值处理。 另外还要
      说明的一点就是fscanf()函数读到空白符时, 便自动结束, 在使用时要特别注意。
    3. 文件的随机读写
      有时用户想直接读取文件中间某处的信息, 若用文件的顺序读写必须从文件
      头开始直到要求的文件位置再读, 这显然不方便。Turbo C2.0提供了一组文件的
      随机读写函数, 即可以将文件位置指针定位在所要求读写的地方直接读写。
      文件的随机读写函数如下:
      int fseek (FILE *stream, long offset, int fromwhere);
      int fread(void *buf, int size, int count, FILE *stream);
      int fwrite(void *buf, int size, int count, FILE *stream);
      long ftell(FILE *stream);
      fseek()函数的作用是将文件的位置指针设置到从fromwhere开始的第offset
      字节的位置上, 其中fromwhere是下列几个宏定义之一:
      文件位置指针起始计算位置fromwhere
      ━━━━━━━━━━━━━━━━━━━━━━━━━━━
      符号常数 数值 含义
      ───────────────────────────
      SEEK_SET 0 从文件开头
      SEEK_CUR 1 从文件指针的现行位置
      SEEK_END 2 从文件末尾
      ━━━━━━━━━━━━━━━━━━━━━━━━━━━
      offset是指文件位置指针从指定开始位置(fromwhere指出的位置)跳过的字
      节数。它是一个长整型量, 以支持大于64K字节的文件。fseek()函数一般用于对
      二进制文件进行操作。
      当fseek()函数返回0时表明操作成功, 返回非0表示失败。
      下面程序从二进制文件test_b.dat中读取第8个字节。
      例13:
      #include<stdio.h>
      main()
      {
      FILE *fp;
      if((fp=fopen(“test_b.dat”, “rb”))==NULL)
      {
      printf(“Can’t open file”);
      exit(1);
      }
      fseek(fp, 8. 1, SEEK_SET);
      fgetc(fp);
      fclose(fp);
      }
      fread()函数是从文件中读count个字段, 每个字段长度为size个字节, 并把
      它们存放到buf指针所指的缓冲器中。
      fwrite()函数是把buf指针所指的缓冲器中, 长度为size个字节的count个字
      段写到stream指向的文件中去。
      随着读和写字节数的增大, 文件位置指示器也增大, 读多少个字节, 文件位
      置指示器相应也跳过多少个字节。读写完毕函数返回所读和所写的字段个数。
      ftell()函数返回文件位置指示器的当前值, 这个值是指示器从文件头开始
      算起的字节数, 返回的数为长整型数, 当返回-1时, 表明出现错误。
      下面程序把一个浮点数组以二进制方式写入文件test_b.dat中。
      例14:
      #include <stdio.h>
      main()
      {
      float f[6]={3.2, -4.34, 25.04, 0.1, 50.56, 80.5};
      /定义浮点数组并初始化/
      int i;
      FILE *fp;
      fp=fopen(“test_b.dat”, “wb”); /创建一个二进制文件只写/
      fwrite(f, sizeof(float), 6, fp);/将6个浮点数写入文件中/
      fclose(fp); /关闭文件/
      }
      下面例子从test_b.dat文件中读100个整型数, 并把它们放到dat数组中。
      例15:
      #include <stdio.h>
      main()
      {
      FILE *fp;
      int dat[100];
      fp=fopen(“test_b.dat”, “rb”);/打开一个二进制文件只读/
      if(fread(dat, sizeof(int), 100, fp)!=100)
      /判断是否读了100个数/
      {
      if(feof(fp))
      printf(“End of file”); /不到100个数文件结束/
      else
      printf(“Read error”); /读数错误/
      fclose(fp); /关闭文件/
      }
      注意:
      当用标准文件函数对文件进行读写操作时, 首先将所读写的内容放进缓冲区,
      即写函数只对输出缓冲区进行操作, 读函数只对输入缓冲区进行操作。例如向一
      个文件写入内容, 所写的内容将首先放在输出缓冲区中, 直到输出缓冲区存满或
      使用fclose()函数关闭文件时, 缓冲区的内容才会写入文件中。若无fclose()
      函数, 则不会向文件中存入所写的内容或写入的文件内容不全。有一个对缓冲区
      进行刷新的函数, 即fflush(), 其调用格式为:
      int fflush(FILE *stream);
      该函数将输出缓冲区的内容实际写入文件中, 而将输入缓冲区的内容清除掉。
    4. feof()和rewind()函数
      这两个函数的调用格式为:
      int feof(FILE *stream);
      int rewind(FILE *stream);
      feof()函数检测文件位置指示器是否到达了文件结尾, 若是则返回一个非0
      值, 否则返回0。这个函数对二进制文件操作特别有用, 因为二进制文件中, 文
      件结尾标志EOF也是一个合法的二进制数, 只简单的检查读入字符的值来判断文
      件是否结束是不行的。如果那样的话, 可能会造成文件未结尾而被认为结尾, 所
      以就必须有feof()函数。
      下面的这条语句是常用的判断文件是否结束的方法。
      while(!feof(fp))
      fgetc(fp);
      while为循环语句, 将在下面介绍。
      rewind()函数用于把文件位置指示器移到文件的起点处, 成功时返回0, 否
      则, 返回非0值。
      1.2.2 非标准文件函数
      这类函数最早用于UNIX操作系统, ANSI标准未定义, 但有时也经常用到,
      DOS 3.0以上版本支持这些函数。它们的头文件为io.h。
      一、文件的打开和关闭
    5. open()函数
      open()函数的作用是打开文件, 其调用格式为:
      int open(char *filename, int access);
      该函数表示按access的要求打开名为filename的文件, 返回值为文件描述字,
      其中access有两部分内容: 基本模式和修饰符, 两者用" "(“或”)方式连接。修
      饰符可以有多个, 但基本模式只能有一个。access的规定如表3-2。
      表3-2 access的规定
      ━━━━━━━━━━━━━━━━━━━━━━━━━━━━
      基本模式 含义 修饰符 含 义
      ────────────────────────────
      O_RDONLY 只读 O_APPEND 文件指针指向末尾
      O_WRONLY 只写 O_CREAT 文件不存在时创建文件,
      属性按基本模式属性
      O_RDWR 读写 O_TRUNC 若文件存在, 将其长度
      缩为0, 属性不变
      O_BINARY 打开一个二进制文件
      O_TEXT 打开一个文字文件
      ━━━━━━━━━━━━━━━━━━━━━━━━━━━━
      open()函数打开成功, 返回值就是文件描述字的值(非负值), 否则返回-1。
    6. close()函数
      close()函数的作用是关闭由open()函数打开的文件, 其调用格式为:
      int close(int handle);
      该函数关闭文件描述字handle相连的文件。
      二、读写函数
    7. read()函数
      read()函数的调用格式为:
      int read(int handle, void *buf, int count);
      read()函数从handle(文件描述字)相连的文件中, 读取count个字节放到buf
      所指的缓冲区中, 返回值为实际所读字节数, 返回-1表示出错。返回0 表示文件
      结束。
    8. write()函数
      write()函数的调用格式为:
      int write(int handle, void *buf, int count);
      write()函数把count个字节从buf指向的缓冲区写入与handle相连的文件中,
      返回值为实际写入的字节数。
      三、随机定位函数
    9. lseek()函数
      lseek()函数的调用格式为:
      int lseek(int handle, long offset, int fromwhere);
      该函数对与handle相连的文件位置指针进行定位, 功能和用法与fseek() 函
      数相同。
    10. tell()函数
      tell()函数的调用格式为:
      long tell(int handle);
      该函数返回与handle相连的文件现生位置指针, 功能和用法与ftell()相同。

C文件操作 收藏
13.3 文件的打开与关闭
文件在进行读写操作之前要先打开,使用完毕要关闭。所谓打开文件,实际上是建立文件的各种有关信息,并使文件指针指向该文件,以便进行其它操作。关闭文件则断开指针与文件之间的联系,也就禁止再对该文件进行操作。

在C语言中,文件操作都是由库函数来完成的。在本章内将介绍主要的文件操作函数。

13.3.1 文件的打开(fopen函数)
fopen函数用来打开一个文件,其调用的一般形式为:

文件指针名=fopen(文件名,使用文件方式);

其中,

“文件指针名”必须是被说明为FILE 类型的指针变量;

“文件名”是被打开文件的文件名;

“使用文件方式”是指文件的类型和操作要求。

“文件名”是字符串常量或字符串数组。

例如:

FILE *fp;

fp=(“file a”,“r”);

其意义是在当前目录下打开文件file a,只允许进行“读”操作,并使fp指向该文件。

又如:

FILE *fphzk

fphzk=(“c:\hzk16”,“rb”)

其意义是打开C驱动器磁盘的根目录下的文件hzk16,这是一个二进制文件,只允许按二进制方式进行读操作。两个反斜线“\ ”中的第一个表示转义字符,第二个表示根目录。

使用文件的方式共有12种,下面给出了它们的符号和意义。

文件使用方式
意义
“rt”
只读打开一个文本文件,只允许读数据
“wt”
只写打开或建立一个文本文件,只允许写数据
“at”
追加打开一个文本文件,并在文件末尾写数据
“rb”
只读打开一个二进制文件,只允许读数据
“wb”
只写打开或建立一个二进制文件,只允许写数据
“ab”
追加打开一个二进制文件,并在文件末尾写数据
“rt+”
读写打开一个文本文件,允许读和写
“wt+”
读写打开或建立一个文本文件,允许读写
“at+”
读写打开一个文本文件,允许读,或在文件末追加数据
“rb+”
读写打开一个二进制文件,允许读和写
“wb+”
读写打开或建立一个二进制文件,允许读和写
“ab+”
读写打开一个二进制文件,允许读,或在文件末追加数据

对于文件使用方式有以下几点说明:

  1. 文件使用方式由r,w,a,t,b,+六个字符拼成,各字符的含义是:

r(read): 读

w(write): 写

a(append): 追加

t(text): 文本文件,可省略不写

b(banary): 二进制文件

+: 读和写

  1. 凡用“r”打开一个文件时,该文件必须已经存在,且只能从该文件读出。

  2. 用“w”打开的文件只能向该文件写入。若打开的文件不存在,则以指定的文件名建立该文件,若打开的文件已经存在,则将该文件删去,重建一个新文件。

  3. 若要向一个已存在的文件追加新的信息,只能用“a”方式打开文件。但此时该文件必须是存在的,否则将会出错。

  4. 在打开一个文件时,如果出错,fopen将返回一个空指针值NULL。在程序中可以用这一信息来判别是否完成打开文件的工作,并作相应的处理。因此常用以下程序段打开文件:

  5. if((fp=fopen(“c:\hzk16”,“rb”)==NULL)

{

printf("\nerror on open c:\hzk16 file!");

getch();

exit(1);

}

这段程序的意义是,如果返回的指针为空,表示不能打开C盘根目录下的hzk16文件,则给出提示信息“error on open c:\ hzk16 file!”,下一行getch()的功能是从键盘输入一个字符,但不在屏幕上显示。在这里,该行的作用是等待,只有当用户从键盘敲任一键时,程序才继续执行,因此用户可利用这个等待时间阅读出错提示。敲键后执行exit(1)退出程序。

  1. 把一个文本文件读入内存时,要将ASCII码转换成二进制码,而把文件以文本方式写入磁盘时,也要把二进制码转换成ASCII码,因此文本文件的读写要花费较多的转换时间。对二进制文件的读写不存在这种转换。

  2. 标准输入文件(键盘),标准输出文件(显示器),标准出错输出(出错信息)是由系统打开的,可直接使用。

13.3.2 文件关闭函数(fclose函数)
文件一旦使用完毕,应用关闭文件函数把文件关闭,以避免文件的数据丢失等错误。

fclose函数调用的一般形式是:

fclose(文件指针);

例如:

fclose(fp);

正常完成关闭文件操作时,fclose函数返回值为0。如返回非零值则表示有错误发生。

13.4 文件的读写
对文件的读和写是最常用的文件操作。在C语言中提供了多种文件读写的函数:

·字符读写函数 :fgetc和fputc

·字符串读写函数:fgets和fputs

·数据块读写函数:freed和fwrite

·格式化读写函数:fscanf和fprinf

下面分别予以介绍。使用以上函数都要求包含头文件stdio.h。

13.4.1 字符读写函数fgetc和fputc
字符读写函数是以字符(字节)为单位的读写函数。每次可从文件读出或向文件写入一个字符。

  1. 读字符函数fgetc

fgetc函数的功能是从指定的文件中读一个字符,函数调用的形式为:

字符变量=fgetc(文件指针);

例如:

ch=fgetc(fp);

其意义是从打开的文件fp中读取一个字符并送入ch中。

对于fgetc函数的使用有以下几点说明:

  1. 在fgetc函数调用中,读取的文件必须是以读或读写方式打开的。

  2. 读取字符的结果也可以不向字符变量赋值,

例如:

fgetc(fp);

但是读出的字符不能保存。

  1. 在文件内部有一个位置指针。用来指向文件的当前读写字节。在文件打开时,该指针总是指向文件的第一个字节。使用fgetc 函数后,该位置指针将向后移动一个字节。 因此可连续多次使用fgetc函数,读取多个字符。应注意文件指针和文件内部的位置指针不是一回事。文件指针是指向整个文件的,须在程序中定义说明,只要不重新赋值,文件指针的值是不变的。文件内部的位置指针用以指示文件内部的当前读写位置,每读写一次,该指针均向后移动,它不需在程序中定义说明,而是由系统自动设置的。

【例13.1】读入文件c1.doc,在屏幕上输出。

#include<stdio.h>

main()

{

FILE *fp;

char ch;

if((fp=fopen(“d:\jrzh\example\c1.txt”,“rt”))==NULL)

{

printf("\nCannot open file strike any key exit!");

getch();

exit(1);

}

ch=fgetc(fp);

while(ch!=EOF)

{

putchar(ch);

ch=fgetc(fp);

}

fclose(fp);

}
本例程序的功能是从文件中逐个读取字符,在屏幕上显示。程序定义了文件指针fp,以读文本文件方式打开文件“d:\jrzh\example\ex1_1.c”,并使fp指向该文件。如打开文件出错,给出提示并退出程序。程序第12行先读出一个字符,然后进入循环,只要读出的字符不是文件结束标志(每个文件末有一结束标志EOF)就把该字符显示在屏幕上,再读入下一字符。每读一次,文件内部的位置指针向后移动一个字符,文件结束时,该指针指向EOF。执行本程序将显示整个文件。

  1. 写字符函数fputc

fputc函数的功能是把一个字符写入指定的文件中,函数调用的形式为:

fputc(字符量,文件指针);

其中,待写入的字符量可以是字符常量或变量,例如:

fputc(‘a’,fp);

其意义是把字符a写入fp所指向的文件中。

对于fputc函数的使用也要说明几点:

  1. 被写入的文件可以用写、读写、追加方式打开,用写或读写方式打开一个已存在的文件时将清除原有的文件内容,写入字符从文件首开始。如需保留原有文件内容,希望写入的字符以文件末开始存放,必须以追加方式打开文件。被写入的文件若不存在,则创建该文件。

  2. 每写入一个字符,文件内部位置指针向后移动一个字节。

  3. fputc函数有一个返回值,如写入成功则返回写入的字符,否则返回一个EOF。可用此来判断写入是否成功。

【例13.2】从键盘输入一行字符,写入一个文件,再把该文件内容读出显示在屏幕上。

#include<stdio.h>

main()

{

FILE *fp;

char ch;

if((fp=fopen(“d:\jrzh\example\string”,“wt+”))==NULL)

{

printf(“Cannot open file strike any key exit!”);

getch();

exit(1);

}

printf(“input a string:\n”);

ch=getchar();

while (ch!=’\n’)

{

fputc(ch,fp);

ch=getchar();

}

rewind(fp);

ch=fgetc(fp);

while(ch!=EOF)

{

putchar(ch);

ch=fgetc(fp);

}

printf("\n");

fclose(fp);

}

程序中第6行以读写文本文件方式打开文件string。程序第13行从键盘读入一个字符后进入循环,当读入字符不为回车符时,则把该字符写入文件之中,然后继续从键盘读入下一字符。每输入一个字符,文件内部位置指针向后移动一个字节。写入完毕,该指针已指向文件末。如要把文件从头读出,须把指针移向文件头,程序第19行rewind函数用于把fp所指文件的内部位置指针移到文件头。第20至25行用于读出文件中的一行内容。

【例13.3】把命令行参数中的前一个文件名标识的文件,复制到后一个文件名标识的文件中,如命令行中只有一个文件名则把该文件写到标准输出文件(显示器)中。

#include<stdio.h>

main(int argc,char *argv[])

{

FILE *fp1,*fp2;

char ch;

if(argc==1)

{

printf(“have not enter file name strike any key exit”);

getch();

exit(0);

}

if((fp1=fopen(argv[1],“rt”))==NULL)

{

printf(“Cannot open %s\n”,argv[1]);

getch();

exit(1);

}

if(argc==2) fp2=stdout;

else if((fp2=fopen(argv[2],“wt+”))==NULL)

{

printf(“Cannot open %s\n”,argv[1]);

getch();

exit(1);

}

while((ch=fgetc(fp1))!=EOF)

fputc(ch,fp2);

fclose(fp1);

fclose(fp2);

}

本程序为带参的main函数。程序中定义了两个文件指针fp1和fp2,分别指向命令行参数中给出的文件。如命令行参数中没有给出文件名,则给出提示信息。程序第18行表示如果只给出一个文件名,则使fp2指向标准输出文件(即显示器)。程序第25行至28行用循环语句逐个读出文件1中的字符再送到文件2中。再次运行时,给出了一个文件名,故输出给标准输出文件stdout,即在显示器上显示文件内容。第三次运行,给出了二个文件名,因此把string中的内容读出,写入到OK之中。可用DOS命令type显示OK的内容。

13.4.2 字符串读写函数fgets和fputs

  1. 读字符串函数fgets

函数的功能是从指定的文件中读一个字符串到字符数组中,函数调用的形式为:

fgets(字符数组名,n,文件指针);

其中的n是一个正整数。表示从文件中读出的字符串不超过 n-1个字符。在读入的最后一个字符后加上串结束标志’\0’。

例如:

fgets(str,n,fp);

的意义是从fp所指的文件中读出n-1个字符送入字符数组str中。

【例13.4】从string文件中读入一个含10个字符的字符串。

#include<stdio.h>

main()

{

FILE *fp;

char str[11];

if((fp=fopen(“d:\jrzh\example\string”,“rt”))==NULL)

{

printf("\nCannot open file strike any key exit!");

getch();

exit(1);

}

fgets(str,11,fp);

printf("\n%s\n",str);

fclose(fp);

}

本例定义了一个字符数组str共11个字节,在以读文本文件方式打开文件string后,从中读出10个字符送入str数组,在数组最后一个单元内将加上’\0’,然后在屏幕上显示输出str数组。输出的十个字符正是例13.1程序的前十个字符。

对fgets函数有两点说明:

  1. 在读出n-1个字符之前,如遇到了换行符或EOF,则读出结束。

  2. fgets函数也有返回值,其返回值是字符数组的首地址。

  1. 写字符串函数fputs

fputs函数的功能是向指定的文件写入一个字符串,其调用形式为:

fputs(字符串,文件指针);

其中字符串可以是字符串常量,也可以是字符数组名,或指针变量,例如:

fputs(“abcd“,fp);

其意义是把字符串“abcd”写入fp所指的文件之中。

【例13.5】在例13.2中建立的文件string中追加一个字符串。

#include<stdio.h>

main()

{

FILE *fp;

char ch,st[20];

if((fp=fopen(“string”,“at+”))==NULL)

{

printf(“Cannot open file strike any key exit!”);

getch();

exit(1);

}

printf(“input a string:\n”);

scanf("%s",st);

fputs(st,fp);

rewind(fp);

ch=fgetc(fp);

while(ch!=EOF)

{

putchar(ch);

ch=fgetc(fp);

}

printf("\n");

fclose(fp);

}

本例要求在string文件末加写字符串,因此,在程序第6行以追加读写文本文件的方式打开文件string。然后输入字符串,并用fputs函数把该串写入文件string。在程序15行用rewind函数把文件内部位置指针移到文件首。再进入循环逐个显示当前文件中的全部内容。

13.4.3 数据块读写函数fread和fwtrite
C语言还提供了用于整块数据的读写函数。可用来读写一组数据,如一个数组元素,一个结构变量的值等。

读数据块函数调用的一般形式为:

fread(buffer,size,count,fp);

写数据块函数调用的一般形式为:

fwrite(buffer,size,count,fp);

其中:

buffer 是一个指针,在fread函数中,它表示存放输入数据的首地址。在fwrite函数中,它表示存放输出数据的首地址。

size 表示数据块的字节数。

count 表示要读写的数据块块数。

fp 表示文件指针。

例如:

fread(fa,4,5,fp);

其意义是从fp所指的文件中,每次读4个字节(一个实数)送入实数组fa中,连续读5次,即读5个实数到fa中。

【例13.6】从键盘输入两个学生数据,写入一个文件中,再读出这两个学生的数据显示在屏幕上。

#include<stdio.h>

struct stu

{

char name[10];

int num;

int age;

char addr[15];

}boya[2],boyb[2],*pp,*qq;

main()

{

FILE *fp;

char ch;

int i;

pp=boya;

qq=boyb;

if((fp=fopen(“d:\jrzh\example\stu_list”,“wb+”))==NULL)

{

printf(“Cannot open file strike any key exit!”);

getch();

exit(1);

}

printf("\ninput data\n");

for(i=0;i<2;i++,pp++)

scanf("%s%d%d%s",pp->name,&pp->num,&pp->age,pp->addr);

pp=boya;

fwrite(pp,sizeof(struct stu),2,fp);

rewind(fp);

fread(qq,sizeof(struct stu),2,fp);

printf("\n\nname\tnumber age addr\n");

for(i=0;i<2;i++,qq++)

printf("%s\t%5d%7d %s\n",qq->name,qq->num,qq->age,qq->addr);

fclose(fp);

}

本例程序定义了一个结构stu,说明了两个结构数组boya和boyb以及两个结构指针变量pp和qq。pp指向boya,qq指向boyb。程序第16行以读写方式打开二进制文件“stu_list”,输入二个学生数据之后,写入该文件中,然后把文件内部位置指针移到文件首,读出两块学生数据后,在屏幕上显示。

[转]流式文件的打开,关闭,读,写,定位学习。
定义文件指针形式:FILE * 指针变量标识符;

例如 FILE * fp; fp称为指向一个文件的指针。

文件操作函数

文件打开函数 fopen

形式:文件指针名 = fopen(文件名,使用文件方式);

例如 :

FILE *fp;
fp=(“file a”,“r”);

意思是在当前目录下打开文件file a,只允许进行“读操作”,并使fp指向该文件。

又如:

FILE *fp
fp=("c:\file b’,“rb”)

意思是打开c驱动器磁盘根目录下的文件file b,只允许进行2进制的读操作。

文件使用方式 意 义
“rt” 只读打开一个文本文件,只允许读数据
“wt” 只写打开或建立一个文本文件,只允许写数据
“at” 追加打开一个文本文件,并在文件末尾写数据
“rb” 只读打开一个二进制文件,只允许读数据
“wb” 只写打开或建立一个二进制文件,只允许写数据
“ab” 追加打开一个二进制文件,并在文件末尾写数据
“rt+” 读写打开一个文本文件,允许读和写
“wt+” 读写打开或建立一个文本文件,允许读写
“at+” 读写打开一个文本文件,允许读,或在文件末追加数 据
“rb+” 读写打开一个二进制文件,允许读和写
“wb+” 读写打开或建立一个二进制文件,允许读和写
“ab+” 读写打开一个二进制文件,允许读,或在文件末追加数据

对于文件使用方式有以下几点说明:

  1. 文件使用方式由r,w,a,t,b,+六个字符拼成,各字符的含义是:
    r(read): 读
    w(write): 写
    a(append): 追加
    t(text): 文本文件,可省略不写
    b(banary): 二进制文件
    +: 读和写
  2. 凡用“r”打开一个文件时,该文件必须已经存在, 且只能从该文件读出。
  3. 用“w”打开的文件只能向该文件写入。 若打开的文件不存在,则以指定的文件名建立该文件,若打开的文件已经存在,则将该文件删去,重建一个新文件。
  4. 若要向一个已存在的文件追加新的信息,只能用“a ”方式打开文件。但此时该文件必须是存在的,否则将会出错。
  5. 在打开一个文件时,如果出错,fopen将返回一个空指针值NULL。在程序中可以用这一信息来判别是否完成打开文件的工作,并作相应的处理。因此常用以下程序段打开文件:
    if((fp=fopen(“c:\hzk16”,“rb”)==NULL)
    {
    printf("\nerror on open c:\hzk16 file!");
    getch();
    exit(1);
    }
    这段程序的意义是,如果返回的指针为空,表示不能打开C盘根目录下的hzk16文件,则给出提示信息“error on open c:\ hzk16file!”,下一行getch()的功能是从键盘输入一个字符,但不在屏幕上显示。在这里,该行的作用是等待, 只有当用户从键盘敲任一键时,程序才继续执行, 因此用户可利用这个等待时间阅读出错提示。敲键后执行exit(1)退出程序。
  6. 把一个文本文件读入内存时,要将ASCII码转换成二进制码, 而把文件以文本方式写入磁盘时,也要把二进制码转换成ASCII码,因此文本文件的读写要花费较多的转换时间。对二进制文件的读写不存在这种转换。
  7. 标准输入文件(键盘),标准输出文件(显示器 ),标准出错输出(出错信息)是由系统打开的,可直接使用。文件关闭函数fClose文件一旦使用完毕,应用关闭文件函数把文件关闭, 以避免文件的数据丢失等错误。
    fclose函数
    调用的一般形式是: fclose(文件指针); 例如:
    fclose(fp); 正常完成关闭文件操作时,fclose函数返回值为0。如返回非零值则表示有错误发生。文件的读写对文件的读和写是最常用的文件操作。
    在C语言中提供了多种文件读写的函数:
    ·字符读写函数 :fgetc和fputc
    ·字符串读写函数:fgets和fputs
    ·数据块读写函数:freed和fwrite
    ·格式化读写函数:fscanf和fprinf
    下面分别予以介绍。使用以上函数都要求包含头文件stdio.h。字符读写函数fgetC和fputC字符读写函数是以字符(字节)为单位的读写函数。 每次可从文件读出或向文件写入一个字符。
    一、读字符函数fgetc
    fgetc函数的功能是从指定的文件中读一个字符,函数调用的形式为: 字符变量=fgetc(文件指针); 例如:ch=fgetc(fp);其意义是从打开的文件fp中读取一个字符并送入ch中。
    对于fgetc函数的使用有以下几点说明:
  8. 在fgetc函数调用中,读取的文件必须是以读或读写方式打开的。
  9. 读取字符的结果也可以不向字符变量赋值,例如:fgetc(fp);但是读出的字符不能保存。
  10. 在文件内部有一个位置指针。用来指向文件的当前读写字节。在文件打开时,该指针总是指向文件的第一个字节。使用fgetc 函数后, 该位置指针将向后移动一个字节。 因此可连续多次使用fgetc函数,读取多个字符。 应注意文件指针和文件内部的位置指针不是一回事。文件指针是指向整个文件的,须在程序中定义说明,只要不重新赋值,文件指针的值是不变的。文件内部的位置指针用以指示文件内部的当前读写位置,每读写一次,该指针均向后移动,它不需在程序中定义说明,而是由系统自动设置的。
    [例10.1]读入文件e10-1.c,在屏幕上输出。
    #include<stdio.h>
    main()
    {
    FILE *fp;
    char ch;
    if((fp=fopen(“e10_1.c”,“rt”))==NULL)
    {
    printf(“Cannot open file strike any key exit!”);
    getch();
    exit(1);
    }
    ch=fgetc(fp);
    while (ch!=EOF)
    {
    putchar(ch);
    ch=fgetc(fp);
    }
    fclose(fp);
    }
    本例程序的功能是从文件中逐个读取字符,在屏幕上显示。 程序定义了文件指针fp,以读文本文件方式打开文件“e10_1.c”, 并使fp指向该文件。如打开文件出错, 给出提示并退出程序。程序第12行先读出一个字符,然后进入循环, 只要读出的字符不是文件结束标志(每个文件末有一结束标志EOF)就把该字符显示在屏幕上,再读入下一字符。每读一次,文件内部的位置指针向后移动一个字符,文件结束时,该指针指向EOF。执行本程序将显示整个文件。
    二、写字符函数fputc
    fputc函数的功能是把一个字符写入指定的文件中,函数调用的 形式为: fputc(字符量,文件指针); 其中,待写入的字符量可以是字符常量或变量,例如:fputc(‘a’,fp);其意义是把字符a写入fp所指向的文件中。
    对于fputc函数的使用也要说明几点:
  11. 被写入的文件可以用、写、读写,追加方式打开,用写或读写方式打开一个已存在的文件时将清除原有的文件内容,写入字符从文件首开始。如需保留原有文件内容,希望写入的字符以文件末开始存放,必须以追加方式打开文件。被写入的文件若不存在,则创建该文件。
  12. 每写入一个字符,文件内部位置指针向后移动一个字节。
  13. fputc函数有一个返回值,如写入成功则返回写入的字符, 否则返回一个EOF。可用此来判断写入是否成功。
    [例10.2]从键盘输入一行字符,写入一个文件, 再把该文件内容读出显示在屏幕上。
    #include<stdio.h>
    main()
    {
    FILE *fp;
    char ch;
    if((fp=fopen(“string”,“wt+”))NULL)
    {
    printf(“Cannot open file strike any key exit!”);
    getch();
    exit(1);
    }
    printf(“input a string:\n”);
    ch=getchar();
    while (ch!=’\n’)
    {
    fputc(ch,fp);
    ch=getchar();
    }
    rewind(fp);
    ch=fgetc(fp);
    while(ch!=EOF)
    {
    putchar(ch);
    ch=fgetc(fp);
    }
    printf("\n");
    fclose(fp);
    }
    程序中第6行以读写文本文件方式打开文件string。程序第13行从键盘读入一个字符后进入循环,当读入字符不为回车符时, 则把该字符写入文件之中,然后继续从键盘读入下一字符。 每输入一个字符,文件内部位置指针向后移动一个字节。写入完毕, 该指针已指向文件末。如要把文件从头读出,须把指针移向文件头, 程序第19行rewind函数用于把fp所指文件的内部位置指针移到文件头。 第20至25行用于读出文件中的一行内容。
    [例10.3]把命令行参数中的前一个文件名标识的文件, 复制到后一个文件名标识的文件中, 如命令行中只有一个文件名则把该文件写到标准输出文件(显示器)中。
    #include<stdio.h>
    main(int argc,char *argv[])
    {
    FILE *fp1,*fp2;
    char ch;
    if(argc
    1)
    {
    printf(“have not enter file name strike any key exit”);
    getch();
    exit(0);
    }
    if((fp1=fopen(argv[1],“rt”))NULL)
    {
    printf(“Cannot open %s\n”,argv[1]);
    getch();
    exit(1);
    }
    if(argc
    2) fp2=stdout;
    else if((fp2=fopen(argv[2],“wt+”))==NULL)
    {
    printf(“Cannot open %s\n”,argv[1]);
    getch();
    exit(1);
    }
    while((ch=fgetc(fp1))!=EOF)
    fputc(ch,fp2);
    fclose(fp1);
    fclose(fp2);
    }
    本程序为带参的main函数。程序中定义了两个文件指针 fp1 和fp2,分别指向命令行参数中给出的文件。如命令行参数中没有给出文件名,则给出提示信息。程序第18行表示如果只给出一个文件名,则使fp2指向标准输出文件(即显示器)。程序第25行至28行用循环语句逐个读出文件1中的字符再送到文件2中。再次运行时,给出了一个文件名(由例10.2所建立的文件), 故输出给标准输出文件stdout,即在显示器上显示文件内容。第三次运行,给出了二个文件名,因此把string中的内容读出,写入到OK之中。可用DOS命令type显示OK的内容:

猜你喜欢

转载自blog.csdn.net/qq_43718731/article/details/123390253