标准C库对文件的操作

2024-05-09 18:20
文章标签 操作 标准 库对

本文主要是介绍标准C库对文件的操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

fopen

由于是标准C库,因此头文件只需包含#include <stdio.h>即可
fopen的api有三个
FILE *fopen(const char *path, const char *mode);
FILE *fdopen(int fd, const char *mode);
FILE *freopen(const char *path, const char *mode, FILE *stream);
常用的是第一个:**FILE *fopen(const char path, const char mode);

const char *path

文件的路径

const char *mode

char 要加引号!!!
以什么参数打开文件
“r” :以只读方式打开文件,该文件必须存在。
“w” :打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失。若文件不存在则建立该文件。
“a” :以附加的方式打开只写文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾,即文件原先的内容会被保留。(EOF符保留)
“r+” :以可读写方式打开文件,该文件必须存在。
“w+” :打开可读写文件,若文件存在则文件长度清为零,即该文件内容会消失。若文件不存在则建立该文件。
“a+”:以附加方式打开可读写的文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾后,即文件原先的内容会被保留。 (原来的EOF符不保留)

fwrite

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

const void *ptr

把哪里的数据写入

size_t size

单个写入类型的大小

size_t nmemb

写入的次数

FILE *stream

写到哪个文件

返回值为第三个参数size_t nmemb即写入的次数

fread

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

void *ptr

读到哪里

size_t size

读入类型的大小

size_t nmemb

读入的个数/次数

FILE *stream

从哪个文件里读

返回值为第三个参数size_t nmemb即读入的次数

fseek

*int fseek(FILE stream, long offset, int whence);

FILE *stream

哪个文件

long offset

偏移量

int whence

SEEK_SET 开头
SEEK_END 结尾
SEEK_CUR 当前位置

基本的打开文件,读写文件操作:

#include <stdio.h>
#include <string.h>int main(){char* str="hello world";FILE *fp;char readBuf[128]={"\0"};fp = fopen("./wang.txt","w+");	//注意第二个参数是引号fwrite(str,sizeof(char),strlen(str),fp);	//也可以一次写入那么多数据,下方读数据也同样fwrite(str,sizeof(char)*strlen(str),1,fp);fseek(fp,0,SEEK_SET);	//将光标返回头部fread(readBuf,sizeof(char),strlen(str),fp);printf("read data:%s\n",readBuf);return 0;
}

其实概念跟之前的open,write都是一样的,只不过这个是标准C库的API

fclose

*int fclose(FILE fp);
fclose比较简单,就是传入一个文件描述符即可。

fputc

*int fputc(int c, FILE stream);
将C(可以是字符)写入某个文件中:

#include <stdio.h>int main(){FILE* fp;char *str = "hello world!";fp = fopen("./test.txt","w+");//int fputc(int c, FILE *stream);while(*str != '\0'){fputc(*str,fp);str++;}fclose(fp);return 0;
}

fgetc

*int fgetc(FILE stream);

feof

*int feof(FILE stream);

写入一个结构体到文件中

#include <string.h>
#include <stdlib.h>
#include <stdio.h>struct Test{int a;char c;
};int main(){FILE *fp;struct Test data1 = {10,'a'};struct Test data2;fp = fopen("./wang.txt","w+");int n_write = fwrite(&data1,sizeof(struct Test),1,fp);fseek(fp,0,SEEK_SET);int n_read = fread(&data2,sizeof(struct Test),1,fp);printf("read:%d %c\n",data2.a,data2.c);fclose(fp);return 0;
}

这篇关于标准C库对文件的操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Go标准库常见错误分析和解决办法

《Go标准库常见错误分析和解决办法》Go语言的标准库为开发者提供了丰富且高效的工具,涵盖了从网络编程到文件操作等各个方面,然而,标准库虽好,使用不当却可能适得其反,正所谓工欲善其事,必先利其器,本文将... 目录1. 使用了错误的time.Duration2. time.After导致的内存泄漏3. jsO

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

Python使用DrissionPage中ChromiumPage进行自动化网页操作

《Python使用DrissionPage中ChromiumPage进行自动化网页操作》DrissionPage作为一款轻量级且功能强大的浏览器自动化库,为开发者提供了丰富的功能支持,本文将使用Dri... 目录前言一、ChromiumPage基础操作1.初始化Drission 和 ChromiumPage

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件

Redis中管道操作pipeline的实现

《Redis中管道操作pipeline的实现》RedisPipeline是一种优化客户端与服务器通信的技术,通过批量发送和接收命令减少网络往返次数,提高命令执行效率,本文就来介绍一下Redis中管道操... 目录什么是pipeline场景一:我要向Redis新增大批量的数据分批处理事务( MULTI/EXE

使用Python高效获取网络数据的操作指南

《使用Python高效获取网络数据的操作指南》网络爬虫是一种自动化程序,用于访问和提取网站上的数据,Python是进行网络爬虫开发的理想语言,拥有丰富的库和工具,使得编写和维护爬虫变得简单高效,本文将... 目录网络爬虫的基本概念常用库介绍安装库Requests和BeautifulSoup爬虫开发发送请求解

Oracle存储过程里操作BLOB的字节数据的办法

《Oracle存储过程里操作BLOB的字节数据的办法》该篇文章介绍了如何在Oracle存储过程中操作BLOB的字节数据,作者研究了如何获取BLOB的字节长度、如何使用DBMS_LOB包进行BLOB操作... 目录一、缘由二、办法2.1 基本操作2.2 DBMS_LOB包2.3 字节级操作与RAW数据类型2.