• C语言之文件操作


    目录

    实现文件读写

    打开文件fopen函数的用法

    写文件fprintf函数的用法

    读文件fscanf函数的用法

    写文件fwrite函数的用法

    读文件fread函数的用法

    关闭文件fclose函数的用法


    实现文件读写

    一直以来,我们学习C语言都是数据的处理,这些数据都是在内存中的。一旦程序结束程序结束退出,数据也将灰飞烟灭。文件操作的实现将帮助我们把数据存储到文件中,既硬盘上的文件,如我们所熟知的txt格式,或其他各种后缀的文件,避免程序结束后数据丢失,实现存储数据的功能,甚至充当“数据库”的功能。

    下面详细说明每步的作用及详细办法。

    1、打开文件:要读取或写入文件,首先需要打开它。可以使用fopen函数来打开文件。

    2、读取文件:在打开文件后,可以使用fscanf、fgets等函数来从文件中读取内容。

    3、写入文件:在打开文件后,可以使用fprintf、fputs等函数将数据写入文件。

    4、关闭文件:在文件读写完成后,应该使用fclose函数关闭文件,以释放系统资源。

    以上就是C语言对文件操作的四个步骤及大致解释,下面将展开详细详解!

    打开文件fopen函数的用法

    fopen()函数是C语言中用于打开文件的函数,它的原型如下:

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

    其中,filename参数是要打开的文件名(包括路径),mode参数是打开文件的模式。

    fopen()函数返回一个指向FILE类型结构体的指针,该指针可以用于后续的文件读写操作。如果打开文件失败,则返回NULL。

    mode参数是打开文件的模式,常见的模式有以下几种:

    参数作用
    r以只读方式打开文件,该文件必须存在。
    r+以读/写方式打开文件,该文件必须存在。
    rb+以读/写方式打开一个二进制文件,只允许读/写数据。
    rt+以读/写方式打开一个文本文件,允许读和写。
    w打开只写文件,若文件存在则文件长度清为零,即该文件内容会消失;若文件不存在则创建该文件。
    w+打开可读/写文件,若文件存在则文件长度清为零,即该文件内容会消失;若文件不存在则创建该文件。
    a以附加的方式打开只写文件。若文件不存在,则会创建该文件;如果文件存在,则写入的数据会被加到文件尾后,即文件原先的内容会被保留(EOF 符保留)。
    a+以附加方式打开可读/写的文件。若文件不存在,则会创建该文件,如果文件存在,则写入的数据会被加到文件尾后,即文件原先的内容会被保留(EOF符不保留)。
    wb以只写方式打开或新建一个二进制文件,只允许写数据。
    wb+以读/写方式打开或新建一个二进制文件,允许读和写。
    wt+以读/写方式打开或新建一个文本文件,允许读和写。
    at+以读/写方式打开一个文本文件,允许读或在文本末追加数据。
    ab+以读/写方式打开一个二进制文件,允许读或在文件末追加数据。

    下面是一个简单的示例,演示了如何使用fopen()函数打开一个文本文件:

    1. #include
    2. int main() {
    3. FILE *fp;
    4. fp = fopen("file.txt", "r");
    5. if (fp == NULL) {
    6. printf("Failed to open file.\n");
    7. return 1;
    8. }
    9. // 文件读写操作
    10. fclose(fp);
    11. return 0;
    12. }

    在上述示例中,首先使用fopen()函数打开一个名为"file.txt"的文本文件,并指定以只读模式打开。如果打开文件失败,则输出错误信息并退出程序。

    接下来,可以在fp指针所指向的文件中进行读写操作。最后,使用fclose()函数关闭文件,以释放系统资源。

    需要注意的是,在进行文件操作时,应该检查文件是否成功打开、读取或写入,以及文件是否成功关闭。此外,还应该处理可能出现的错误情况,例如文件不存在或无法访问等。

    在实际应用中,还可以使用其他相关函数,如freopen()、fdopen()等,来重新打开文件或将文件描述符转换为FILE类型指针等操作。根据具体需求,可以选择合适的函数和方法来实现文件读写操作。

    写文件fprintf函数的用法

    fprintf()函数是C语言中用于将格式化数据写入文件的函数,它的原型如下:

    int fprintf(FILE *stream, const char *format, ...);
    

    其中,stream参数是指向已打开文件的指针,format参数是格式化字符串,用于指定要写入的数据类型和格式,后续参数是要写入的数据。

    fprintf()函数返回成功写入的字符数,如果发生错误则返回一个负值。

    控制符作用
    %c字符
    %d 或 %i有符号十进制整数
    %e使用 e 字符的科学科学记数法(尾数和指数)
    %E使用 E 字符的科学科学记数法(尾数和指数)
    %f十进制浮点数
    %g自动选择 %e 或 %f 中合适的表示法
    %G自动选择 %E 或 %f 中合适的表示法
    %o有符号八进制
    %s字符的字符串
    %u无符号十进制整数
    %x无符号十六进制整数
    %X无符号十六进制整数(大写字母)
    %p指针地址
    %n无输出
    %字符

    更多的格式可以参照printf的用法中的格式,可以通用。

    下面是一个简单的示例,演示了如何使用fprintf()函数将数据写入文件:

    1. #include
    2. int main() {
    3. FILE *fp;
    4. fp = fopen("file.txt", "w");
    5. if (fp == NULL) {
    6. printf("Failed to open file.\n");
    7. return 1;
    8. }
    9. int num = 10;
    10. float pi = 3.14159;
    11. char str[] = "Hello, World!";
    12. fprintf(fp, "Number: %d\n", num);
    13. fprintf(fp, "Pi: %.2f\n", pi);
    14. fprintf(fp, "String: %s\n", str);
    15. fclose(fp);
    16. return 0;
    17. }

    在上述示例中,首先使用fopen()函数以写入模式打开一个名为"file.txt"的文本文件。如果打开文件失败,则输出错误信息并退出程序。

    接下来,使用fprintf()函数将数据按照指定的格式写入文件。在这个例子中,我们分别写入一个整数、一个浮点数和一个字符串。格式化字符串中的占位符(如%d、%.2f、%s)会被对应的参数值替换。

    最后,使用fclose()函数关闭文件,以释放系统资源。

    需要注意的是,在进行文件操作时,应该检查文件是否成功打开、读取或写入,以及文件是否成功关闭。此外,还应该处理可能出现的错误情况,例如文件不存在或无法访问等。

    除了fprintf()函数,C语言还提供了其他一些用于写入文件的函数,如fputc()、fputs()等。根据具体需求,可以选择合适的函数和方法来实现文件写入操作。

    需要注意理解的是,fprintf函数虽然和printf函数很像,表示输出,但准确说是是写入的意思,是指程序向文件里写,要清楚数据的流向。

    读文件fscanf函数的用法

    fscanf()函数是C语言中用于从文件中读取格式化数据的函数,它的原型如下:

    int fscanf(FILE *stream, const char *format, ...);
    

    其中,stream参数是指向已打开文件的指针,format参数是格式化字符串,用于指定要读取的数据类型和格式,后续参数是用于存储读取结果的变量。

    fscanf()函数返回成功读取的项目数,如果发生错误则返回一个负值。

    更多fscanf的格式如下表:

    格式作用
    %d读入一个十进制整数
    %i读入十进制,八进制,十六进制整数,与%d类似,但是在编译时通过数据前置或后置来区分进制,如加入“0x”则是十六进制,加入“0”则为八进制。例如串“031”使用%d时会被算作31,但是使用%i时会算作25
    %u读入一个无符号十进制整数
    %f %F %g %G用来输入实数,可以用小数形式或指数形式输入
    %x %x 读入十六进制整数
    %o读入八进制整数
    %s直到遇到一个空格字符(空格字符可以是空白、换行和制表符)
    %c单个字符:读取下一个字符。如果指定了一个不为 1 的宽度 width,函数会读取 width 个字符,并通过参数传递,把它们存储在数组中连续位置。在末尾不会追加空字符

    下面是一个简单的示例,演示了如何使用fscanf()函数从文件中读取数据:

    1. #include
    2. int main() {
    3. FILE *fp;
    4. fp = fopen("file.txt", "r");
    5. if (fp == NULL) {
    6. printf("Failed to open file.\n");
    7. return 1;
    8. }
    9. int num;
    10. float pi;
    11. char str[50];
    12. fscanf(fp, "%d", &num);
    13. fscanf(fp, "%f", &pi);
    14. fscanf(fp, "%s", str);
    15. printf("Number: %d\n", num);
    16. printf("Pi: %.2f\n", pi);
    17. printf("String: %s\n", str);
    18. fclose(fp);
    19. return 0;
    20. }

    在上述示例中,首先使用fopen()函数以只读模式打开一个名为"file.txt"的文本文件。如果打开文件失败,则输出错误信息并退出程序。

    接下来,使用fscanf()函数从文件中按照指定的格式读取数据。在这个例子中,我们分别读取一个整数、一个浮点数和一个字符串。格式化字符串中的占位符(如%d、%f、%s)会将文件中的数据解析并存储到对应的变量中。

    最后,使用printf()函数将读取到的数据输出到控制台。

    需要注意的是,在进行文件操作时,应该检查文件是否成功打开、读取或写入,以及文件是否成功关闭。此外,还应该处理可能出现的错误情况,例如文件不存在或无法访问等。

    除了fscanf()函数,C语言还提供了其他一些用于从文件中读取数据的函数,如fgetc()、fgets()等。根据具体需求,可以选择合适的函数和方法来实现文件读取操作。

    写文件fwrite函数的用法

    fwrite()函数是C语言中用于将数据块写入文件的函数,它的原型如下:

    size_t fwrite(const void *ptr, size_t size, size_t count, FILE *stream);
    

    其中,ptr参数是指向要写入的数据块的指针,size参数是每个数据项的大小(以字节为单位),count参数是要写入的数据项的数量,stream参数是指向已打开文件的指针。

    fwrite()函数返回成功写入的数据项数。如果发生错误或到达文件末尾,则返回一个小于count的值。

    下面是一个简单的示例,演示了如何使用fwrite()函数将数据块写入文件:

    1. #include
    2. struct Person {
    3. char name[50];
    4. int age;
    5. };
    6. int main() {
    7. FILE *fp;
    8. fp = fopen("file.bin", "wb");
    9. if (fp == NULL) {
    10. printf("Failed to open file.\n");
    11. return 1;
    12. }
    13. struct Person p1 = {"John", 25};
    14. struct Person p2 = {"Alice", 30};
    15. fwrite(&p1, sizeof(struct Person), 1, fp);
    16. fwrite(&p2, sizeof(struct Person), 1, fp);
    17. fclose(fp);
    18. return 0;
    19. }

    在上述示例中,首先使用fopen()函数以二进制写入模式打开一个名为"file.bin"的文件。如果打开文件失败,则输出错误信息并退出程序。

    接下来,定义了一个名为Person的结构体,表示一个人的信息,包括姓名和年龄。

    然后,创建了两个Person类型的变量p1和p2,并分别初始化它们的值。

    使用fwrite()函数将p1和p2的数据块写入文件。sizeof(struct Person)用于获取Person结构体的大小,以字节为单位。通过取地址运算符&获取结构体变量的内存地址。

    最后,使用fclose()函数关闭文件,以释放系统资源。

    需要注意的是,在进行文件操作时,应该检查文件是否成功打开、读取或写入,以及文件是否成功关闭。此外,还应该处理可能出现的错误情况,例如文件不存在或无法访问等。

    除了fwrite()函数,C语言还提供了其他一些用于写入文件的函数,如fputc()、fputs()等。根据具体需求,可以选择合适的函数和方法来实现文件写入操作。

    读文件fread函数的用法

    与fwrite是一对,fread()函数是C语言中用于从文件中读取数据块的函数,它的原型如下:

    size_t fread(void *ptr, size_t size, size_t count, FILE *stream);
    

    其中,ptr参数是指向存储读取数据的缓冲区的指针,size参数是每个数据项的大小(以字节为单位),count参数是要读取的数据项的数量,stream参数是指向已打开文件的指针。

    fread()函数返回成功读取的数据项数。如果发生错误或到达文件末尾,则返回一个小于count的值。

    下面是一个简单的示例,演示了如何使用fread()函数从文件中读取数据块:

    1. #include
    2. struct Person {
    3. char name[50];
    4. int age;
    5. };
    6. int main() {
    7. FILE *fp;
    8. fp = fopen("file.bin", "rb");
    9. if (fp == NULL) {
    10. printf("Failed to open file.\n");
    11. return 1;
    12. }
    13. struct Person p1, p2;
    14. fread(&p1, sizeof(struct Person), 1, fp);
    15. fread(&p2, sizeof(struct Person), 1, fp);
    16. printf("Person 1: %s, %d\n", p1.name, p1.age);
    17. printf("Person 2: %s, %d\n", p2.name, p2.age);
    18. fclose(fp);
    19. return 0;
    20. }

    在上述示例中,首先使用fopen()函数以二进制读取模式打开一个名为"file.bin"的文件。如果打开文件失败,则输出错误信息并退出程序。

    接下来,定义了一个名为Person的结构体,表示一个人的信息,包括姓名和年龄。

    然后,创建了两个Person类型的变量p1和p2。

    使用fread()函数从文件中读取p1和p2的数据块。sizeof(struct Person)用于获取Person结构体的大小,以字节为单位。通过取地址运算符&获取结构体变量的内存地址。

    最后,使用printf()函数将读取到的数据输出到控制台,并使用fclose()函数关闭文件,以释放系统资源。

    需要注意的是,在进行文件操作时,应该检查文件是否成功打开、读取或写入,以及文件是否成功关闭。此外,还应该处理可能出现的错误情况,例如文件不存在或无法访问等。

    除了fread()函数,C语言还提供了其他一些用于读取文件的函数,如fgetc()、fgets()等。根据具体需求,可以选择合适的函数和方法来实现文件读取操作。

    关闭文件fclose函数的用法

    fclose()函数用于关闭已打开的文件,切断IO数据流,以释放系统资源并确保文件的正确关闭。它的原型如下:

    int fclose(FILE *stream);
    

    其中,stream参数是指向已打开文件的指针。

    fclose()函数返回一个整数值,如果成功关闭文件,则返回0;如果关闭文件失败,则返回-1。

    下面是一个示例,演示了如何使用fclose()函数关闭文件:

    1. #include
    2. int main() {
    3. FILE *fp;
    4. fp = fopen("file.txt", "r");
    5. if (fp == NULL) {
    6. printf("Failed to open file.\n");
    7. return 1;
    8. }
    9. // 文件操作...
    10. int result = fclose(fp);
    11. if (result == 0) {
    12. printf("File closed successfully.\n");
    13. } else {
    14. printf("Failed to close file.\n");
    15. }
    16. return 0;
    17. }

    在上述示例中,首先使用fopen()函数以只读模式打开一个名为"file.txt"的文件。如果打开文件失败,则输出错误信息并退出程序。

    接下来,进行文件操作(此处省略具体操作)。

    然后,使用fclose()函数关闭已打开的文件。通过传递之前打开文件时返回的文件指针作为参数。

    最后,根据fclose()函数的返回值判断文件是否成功关闭,并输出相应的信息。

    需要注意的是,在进行文件操作时,应该检查文件是否成功打开、读取或写入,以及文件是否成功关闭。此外,还应该处理可能出现的错误情况,例如文件不存在或无法访问等。

    在关闭文件之前,确保已完成对文件的所有操作,以避免数据丢失或不完整的情况。关闭文件后,将无法再对其进行读取或写入操作。

    另外,如果程序中有多个文件需要关闭,可以依次使用fclose()函数关闭它们。每个文件都应该有对应的文件指针,并确保在适当的时候关闭它们,以避免资源泄漏。

    总结起来,fclose()函数是C语言中用于关闭文件的函数,通过传递文件指针作为参数来关闭已打开的文件。在文件操作完成后,及时关闭文件是良好的编程习惯,可以避免资源浪费和潜在的问题。

  • 相关阅读:
    直播系统开发:基于Nginx与Nginx-rtmp-module实现
    Anaconda和Pycharm详细安装 配置教程
    Selenium的定位方式
    软考高级信息系统项目管理师系列之二:信息化和信息系统习题
    K线形态识别_空方尖兵
    vue serve及其与vue-cli-service serve之间的关系
    阳振坤:OceanBase 4.0 核心技术解读
    [源码解析] TensorFlow 分布式之 ClusterCoordinator
    InputStream/OutputStream(文件的输入输出)
    Floyd算法基础
  • 原文地址:https://blog.csdn.net/m0_74293254/article/details/134063524