文件的顺序读写——顺序读写函数——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

相关文章

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

Spring Bean初始化及@PostConstruc执行顺序示例详解

《SpringBean初始化及@PostConstruc执行顺序示例详解》本文给大家介绍SpringBean初始化及@PostConstruc执行顺序,本文通过实例代码给大家介绍的非常详细,对大家的... 目录1. Bean初始化执行顺序2. 成员变量初始化顺序2.1 普通Java类(非Spring环境)(

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:计算字符串