文件的顺序读写——顺序读写函数——fgets、fgetc、fputs、 fputc

2024-03-31 20:12

本文主要是介绍文件的顺序读写——顺序读写函数——fgets、fgetc、fputs、 fputc,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

✨✨ 欢迎大家来到莉莉的博文✨✨

 🎈🎈养成好习惯,先赞后看哦~🎈🎈

目录

一、fgetc和fputc函数

1.1 fputc

 1.2 fgetc

二、fputs和fgets函数

 2.1 fputs函数

2.2 fgets函数 


一、fgetc和fputc函数

1.1 fputc

  • 返回类型int:
  1. 如果成功读取字符,返回的是字符的ASCII码值——char
  2. 如果读取失败或者遇文件末尾,则返回EOF(-1) ——int
  3. 为了统一,将函数的返回类型定为int(char类型提升为int类型)

 1.2 fgetc

  • 返回指定的内部文件位置指示器当前指向的字符。然后,内部文件位置指示器将前进到下一个字符。如果调用时流位于文件末尾,则该函数将返回 EOF 并设置流的文件末尾指示器 (feof) 。
  • 返回值:
  1. 如果发生读取错误,该函数将返回 EOF 并设置流的错误指示器 (ferror)。
  2. 成功后,将返回读取的字符(提升为 int 值)。
  3. 返回类型为 int 以适应特殊值 EOF,该值指示失败:
  4. 如果位置指示器位于文件末尾,则函数返回 EOF 并设置的 eof 指示符 (feof)。
  5. 如果发生其他读取错误,该函数也会返回 EOF,但会设置其错误指示器 (ferror)。

举例:

        创建一个文件,并向其中写入小写字母a到z,然后关闭文件。接着再以读的形式打开这个文件,并将这些字符输出到终端。

#include<stdio.h>
int main()
{// 向文件中输入数据FILE* pf = fopen("text.txt", "w");if (pf == NULL){perror("fopen :w");return 1;}else{char ch = 0;for (ch = 'a'; ch <= 'z'; ch++){fputc(ch, pf);}}fclose(pf);pf = NULL;// 向文件中读取数据FILE* pf2 = fopen("text.txt", "r");if (pf2 == NULL){perror("fopen: r");return 1;}else{int ch = 0; // ch 为int类型,以便接收fgetc的返回值while ((ch = fgetc(pf2)) != EOF){putchar(ch); // 直接输出字符}}fclose(pf2);pf2 = NULL;return 0;
}

二、fputs和fgets函数

 2.1 fputs函数

  •         将 str 指向的字符串写入
  •         该函数从指定的地址 (str) 开始复制,直到到达终止 null 字符 ('\0')。此终止 null 字符不会复制到流中
  •        fputs 与  puts的不同之处在于可以指定目标,而且 fputs 不会写入其他字符,而 puts 会自动在末尾附加一个换行符

举例

        text.txt拼接之前的值

#include <stdio.h>
int main()
{FILE* pFile;char sentence[256];printf("Enter sentence to append: ");fgets(sentence, 256, stdin);pFile = fopen("text.txt", "a");fputs(sentence, pFile);fclose(pFile);return 0;
}

输入:

text.txt拼接后:

2.2 fgets函数

​​

  • str:指向要复制读取的字符串。
  • num:要复制到 str 中的最大字符数(包括终止 null 字符)。
  • stream流:
  1. 指向标识输入流的 FILE 对象的指针。
  2. stdin 可以用作从标准输入读取的参数。
  • 注意:
  1. 中读取字符,并将它们作为字符串存储到 str 中,直到读取 (num-1) 个字符(第num个字符会被自动读成‘\0’)或到达换行符或文件末尾,以先发生者为准。
  2. 换行符‘\n’  使 fgets 停止读取,但它被函数视为有效字符,并包含在复制的字符串中。
  3. 空字符会自动附加到 str 的字符之后。
  4. fgets 与 gets 有很大不同:fgets 不仅接受参数,还允许指定 str 的最大大小,并在字符串中包含任何结束换行符。
    #include <stdio.h>
    int main()
    {FILE* pFile;char my_string[100];pFile = fopen("myfile.txt", "r");if (pFile == NULL) perror("Error opening file");else {if (fgets(my_string, 100, pFile) != NULL)puts(my_string);fclose(pFile);}return 0;
    }

这篇关于文件的顺序读写——顺序读写函数——fgets、fgetc、fputs、 fputc的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/865232

相关文章

postgresql使用UUID函数的方法

《postgresql使用UUID函数的方法》本文给大家介绍postgresql使用UUID函数的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录PostgreSQL有两种生成uuid的方法。可以先通过sql查看是否已安装扩展函数,和可以安装的扩展函数

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

浅析Spring如何控制Bean的加载顺序

《浅析Spring如何控制Bean的加载顺序》在大多数情况下,我们不需要手动控制Bean的加载顺序,因为Spring的IoC容器足够智能,但在某些特殊场景下,这种隐式的依赖关系可能不存在,下面我们就来... 目录核心原则:依赖驱动加载手动控制 Bean 加载顺序的方法方法 1:使用@DependsOn(最直

C#读写文本文件的多种方式详解

《C#读写文本文件的多种方式详解》这篇文章主要为大家详细介绍了C#中各种常用的文件读写方式,包括文本文件,二进制文件、CSV文件、JSON文件等,有需要的小伙伴可以参考一下... 目录一、文本文件读写1. 使用 File 类的静态方法2. 使用 StreamReader 和 StreamWriter二、二进

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字