zoukankan      html  css  js  c++  java
  • C++文件读写操作

     

    语言文件系统称为流文件(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)

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

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

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

    5) ~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)。由此可判断文件打开是否成功。

    2. fclose()函数
        fclose()函数用来关闭一个由fopen()函数打开的文件 , 其调用格式为:
          int fclose(FILE *stream);
        该函数返回一个整型数。当文件关闭成功时, 返回0, 否则返回一个非零值。
    可以根据函数的返回值判断文件是否关闭成功。
        例10:
         #iclude<stdio.h>
         main()
         {
              FILE *fp;                /*定义一个文件指针*/
              int i;
              fp=fopen("CLIB", "rb");  /*打开当前目录名为CLIB的文件只读*/
              if(fp==NULL)             /*判断文件是否打开成功*/
                 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, <variable-list>);
        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, <address-list>);
         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。
        一、文件的打开和关闭
        1. 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。
        2. close()函数
        close()函数的作用是关闭由open()函数打开的文件, 其调用格式为:
         int close(int handle);
        该函数关闭文件描述字handle相连的文件。
        二、读写函数
        1. read()函数
        read()函数的调用格式为:
         int read(int handle, void *buf, int count);
        read()函数从handle(文件描述字)相连的文件中, 读取count个字节放到buf
    所指的缓冲区中, 返回值为实际所读字节数, 返回-1表示出错。返回0 表示文件
    结束。
        2. write()函数
        write()函数的调用格式为:
         int write(int handle, void *buf, int count);
        write()函数把count个字节从buf指向的缓冲区写入与handle相连的文件中,
    返回值为实际写入的字节数。
        三、随机定位函数
        1. lseek()函数
        lseek()函数的调用格式为:
         int lseek(int handle, long offset, int fromwhere);
        该函数对与handle相连的文件位置指针进行定位, 功能和用法与fseek() 函
    数相同。
        2. 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): 二进制文件

    +: 读和写

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

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

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

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

    6) 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)退出程序。

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

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

    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);

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

    3) 在文件内部有一个位置指针。用来指向文件的当前读写字节。在文件打开时,该指针总是指向文件的第一个字节。使用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。执行本程序将显示整个文件。

    2. 写字符函数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函数也有返回值,其返回值是字符数组的首地址。

    2. 写字符串函数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函数的使用有以下几点说明:
    1. 在fgetc函数调用中,读取的文件必须是以读或读写方式打开的。
    2. 读取字符的结果也可以不向字符变量赋值,例如:fgetc(fp);但是读出的字符不能保存。
    3. 在文件内部有一个位置指针。用来指向文件的当前读写字节。在文件打开时,该指针总是指向文件的第一个字节。使用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函数的使用也要说明几点:
    1. 被写入的文件可以用、写、读写,追加方式打开,用写或读写方式打开一个已存在的文件时将清除原有的文件内容,写入字符从文件首开始。如需保留原有文件内容,希望写入的字符以文件末开始存放,必须以追加方式打开文件。被写入的文件若不存在,则创建该文件。
    2. 每写入一个字符,文件内部位置指针向后移动一个字节。
    3. 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的内容:


  • 相关阅读:
    CalcIntegerLength
    ReadIniTest_GetPrivateProfileString
    map test
    逻辑判断
    AppDomain.Unload_MarshalByRefObject
    网络编程
    pymysql
    MySQL多表查询
    MySQL单表查询
    python3 中引用 HTMLTestRunner.py 模块的注意事项
  • 原文地址:https://www.cnblogs.com/sunliming/p/1993075.html
Copyright © 2011-2022 走看看