博客
关于我
按行读文件---->fgets函数
阅读量:175 次
发布时间:2019-02-28

本文共 1718 字,大约阅读时间需要 5 分钟。

在C语言中,使用fgets函数读取文件内容时,需要注意以下几点:

  • fgets函数的工作原理fgets函数从指定的文件流中读取数据,直到遇到换行符'\n'或者文件末尾EOF为止。它返回读取的字符数量,包括换行符,或者返回NULL表示读取失败或文件末尾。

  • 读取数据时的潜在问题

    • 如果文件中存在多个换行符,fgets会将每个换行符都包含在读取的字符串中。
    • 手动处理字符串末尾的换行符可能会导致字符被错误替换,尤其是在字符串末尾存在空格或其他特殊字符时。
  • 解决方法

    • 方法一:检查fgets返回值是否为非NULL,来判断是否读取到有效数据。这样可以避免继续读取无效的数据。
    • 方法二:在读取数据后,手动将字符串末尾的换行符替换为终止字符'\0'。这种方法适用于简单场景,但可能会引入其他问题,比如字符串末尾存在空格或其他特殊字符。
  • 优化建议

    • 优化代码:在读取数据时,直接利用fgets返回值来判断是否读取到有效数据,从而避免手动处理字符串末尾的换行符。
    • 避免乱码:确保读取到的数据不会包含多余的空格或特殊字符。可以使用strlen函数检查字符串长度,或者使用strncmp函数比较字符串末尾的字符。
  • 代码示例

    #define _CRT_SECURE_NO_WARNINGS#include 
    #include
    #include
    //按行向文件写入void test() { FILE* fp = fopen("test.txt", "w"); if (fp == NULL) { printf("打开文件失败"); } char buf[120] = "拨不通的电话信号\n丢失云层上\n孩子别紧张\n生活不是竞技场\n"; fputs(buf, fp); fclose(fp);}//从文件中按行读取void test01() { FILE* fp = fopen("test.txt", "r"); if (fp == NULL) { printf("打开文件失败"); exit(1); } char buf[120]; while (fgets(buf, sizeof(buf), fp)) { printf("%s", buf); }}int main() { test(); test01(); return 0;}
  • 优化后的代码

    #define _CRT_SECURE_NO_WARNINGS#include 
    #include
    #include
    void test() { FILE* fp = fopen("test.txt", "w"); if (fp == NULL) { printf("打开文件失败"); } char buf[120] = "拨不通的电话信号\n丢失云层上\n孩子别紧张\n生活不是竞技场\n"; fputs(buf, fp); fclose(fp);}void test01() { FILE* fp = fopen("test.txt", "r"); if (fp == NULL) { printf("打开文件失败"); exit(1); } char buf[120]; while (fgets(buf, sizeof(buf), fp)) { printf("%s", buf); }}int main() { test(); test01(); return 0;}
  • 通过以上优化,代码更加简洁,且避免了手动处理字符串末尾的换行符,直接利用fgets返回值来判断读取状态,从而更安全地读取文件内容。

    转载地址:http://vhwc.baihongyu.com/

    你可能感兴趣的文章
    OpenCV与AI深度学习 | 基于Python和OpenCV将图像转为ASCII艺术效果
    查看>>
    OpenCV与AI深度学习 | 基于PyTorch实现Faster RCNN目标检测
    查看>>
    OpenCV与AI深度学习 | 基于PyTorch语义分割实现洪水识别(数据集 + 源码)
    查看>>
    OpenCV与AI深度学习 | 基于YOLO11的车体部件检测与分割
    查看>>
    OpenCV与AI深度学习 | 基于YOLOv8 + BotSORT实现球员和足球检测与跟踪 (步骤 + 源码)
    查看>>
    OpenCV与AI深度学习 | 基于YOLOv8的停车对齐检测
    查看>>
    OpenCV与AI深度学习 | 基于机器视觉的磁瓦表面缺陷检测方案
    查看>>
    OpenCV与AI深度学习 | 基于深度学习的轮胎缺陷检测系统
    查看>>
    OpenCV与AI深度学习 | 实战 | OpenCV传统方法实现密集圆形分割与计数(详细步骤 + 代码)
    查看>>
    OpenCV与AI深度学习 | 实战 | OpenCV实现扫描文本矫正应用与实现详解(附源码)
    查看>>
    OpenCV与AI深度学习 | 实战 | 使用YOLOv8 Pose实现瑜伽姿势识别
    查看>>
    OpenCV与AI深度学习 | 实战 | 使用YoloV8实例分割识别猪的姿态(含数据集)
    查看>>
    OpenCV与AI深度学习 | 实战 | 使用姿态估计算法构建简单的健身训练辅助应用程序
    查看>>
    OpenCV与AI深度学习 | 实战 | 基于YoloV5和Mask RCNN实现汽车表面划痕检测(步骤 + 代码)
    查看>>
    OpenCV与AI深度学习 | 实战 | 基于YOLOv9+SAM实现动态目标检测和分割(步骤 + 代码)
    查看>>
    OpenCV与AI深度学习 | 实战 | 基于YOLOv9和OpenCV实现车辆跟踪计数(步骤 + 源码)
    查看>>
    OpenCV与AI深度学习 | 实战 | 文本图片去水印--同时保持文本原始色彩(附源码)
    查看>>
    OpenCV与AI深度学习 | 实战—使用YOLOv8图像分割实现路面坑洞检测(步骤 + 代码)
    查看>>
    OpenCV与AI深度学习 | 实战篇——基于YOLOv8和OpenCV实现车速检测(详细步骤 + 代码)
    查看>>
    OpenCV与AI深度学习 | 实战|OpenCV实时弯道检测(详细步骤+源码)
    查看>>