首页 > 其他分享 >C语言文件操作

C语言文件操作

时间:2022-11-17 21:42:31浏览次数:53  
标签:fp 文件 读取 C语言 char str 操作 指针



相关视频——C语言精华——C语言文件操作,文件打开、关闭、读取、定位如何操作?为你逐一讲解文件操作标准库函数_哔哩哔哩 (゜-゜)つロ 干杯~-bilibili

我的小站——半生瓜のblog


C语言文件操作

  • ​​打开文件​​
  • ​​关闭文件​​
  • ​​读取文件​​
  • ​​fgetc​​
  • ​​fgets​​
  • ​​fread​​
  • ​​写入文件​​
  • ​​fputc​​
  • ​​fputs​​
  • ​​fwrite​​
  • ​​文件定位​​
  • ​​fseek​​
  • ​​rewind​​
  • ​​ftell​​

文件分类:

一种是文本文件,一种是二进制文件。

  • 文本文件:保存的时候,没一个字符对应一个字节。
  • 二进制文件:按照二进制编码保存的文件。

文件操作:

打开文件

打开文件fopen(“文件路径”,“打开方式”)

参数:-(百度百科)

C语言文件操作_打开文件

(选中函数按F1打开msdn文档)

打开文件成功返回一个文件指针,打不开返回 NULL。

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main(void)
{
FILE* fp = fopen("C:\\Users\\XX\\Desktop\\test.txt","r");
if (fp == NULL)
{
printf("打开文件失败\n");
}
char ch = fgetc(fp);
while ((ch = fgetc(fp)) != EOF)
{
printf("%c",ch);
}
fclose(fp);
return 0;

}

关闭文件

fclose();

读取文件

fgetc

char ch  = fgetc();//返回一个字符,一个字符一个字符的读取。

打开文件之后,到关闭文件之前操作,会有一个文件指针定位到你当前操作到哪里了,读取了一个字节,文件指针就会继续往后偏移。


读取完会将文件指针移动到下一个字符。


可以使用循环将全部文本全部内容读取。

fgets

读取一行fgets()

char str[200];
fgets(str,200,fp);
printf("%c",str);

也可以通过循环将内容一行一行的读取出来。

fread

fread想读多少读多少

fread(str存到哪,每个元素大小,读几个,文件);

返回实际读取的大小

fread(str,1,10,fp);

清零

char str[200] = {0};//初始化

memset(str,0,sizeof(str);

int n = fread(str,1,10,fp);
str[n] = '\0';

写入文件

fputc

fputc(‘内容’,文件);

fputs

写入一个字符串

fputs();

char* str = "xxxxxxxxxxxxxxxxxxxxxxx\r\n";
\r\n回车
fputs(str,fp);

fwrite

fwrite想写多少写多少

int num = 123124;
fwrite(&num,sizeof(num),1,fp);
第一个参数类型是void* 可以转化为任意类型
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
typedef struct Person
{
char name[20];
char sex[4];
int age;
}_Person;
int main(void)
{
FILE* fp = fopen("C:\\Users\\XX\\Desktop\\test.txt", "r+");
if (fp == NULL)
{
printf("打开文件失败\n");
}
Person p1 = {"张三","男",20};
fwrite(&p1, 1, sizeof(p1), fp);
fclose(fp);
return 0;

}

C语言文件操作_#include_02

文件定位

文件指针定位

fseek

fseek(fp,0,SEEK_SET)

能够移动文件指针

可以指定文件从哪里开始读取

char str[200];
fseek(fp, 10, SEEK_SET);
fread(str,1,100,fp);

在当前位置再往后移动x个位置

fseek(fp,10,SEEK_CUR);

读取文件最后一行

fseek(fp,0,SEEK_END);
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
typedef struct Person
{
char name[20];
char sex[4];
int age;
}_Person;
int main(void)
{
FILE* fp = fopen("C:\\Users\\XX\\Desktop\\test.txt", "r+");
if (fp == NULL)
{
printf("打开文件失败\n");
}
//读取文件最后一行
fseek(fp,0,SEEK_END);
//反着读
fseek(fp, -1, SEEK_END);
char ch = 0;
int length = 0;
while (fread(&ch, 1, 1, fp))
{
if (ch == '\n')
{
break;
}
fseek(fp,-2,SEEK_CUR);
length++;//统计退了多少格
}
printf("length = %d\n", length);
fseek(fp, -length, SEEK_END);
char* buffer = (char*)malloc(sizeof(char) * length + 1);//多一个空间存储字符串终止符
memset(buffer,0,length+1);
fread(buffer, 1, length,fp);
printf("%s\n",buffer);
fclose(fp);
//释放内存
free(buffer);
return 0;
}

rewind

重置文件指针,返回到文件的开头。

ftell

返回当前指针位置。


文件指针移动了多少个字节,该文件的大小就是多少。

rewind(fp);//重置文件指针到开头
fseek(fp, 0, SEEK_END);//将文件指针定位到结尾
int nSize = ftell(fp);//文件指针偏移量
printf("%d\n", nSize);


标签:fp,文件,读取,C语言,char,str,操作,指针
From: https://blog.51cto.com/u_15333750/5866165

相关文章

  • C语言实现学生成绩管理系统
    相关视频——https://www.bilibili.com/video/BV13z4y117qC?p=8我的小站——半生瓜のblog​代码​实现#define_CRT_SECURE_NO_WARNINGS1#include<stdio.h>#include<conio.......
  • LeetCode刷题(1)【链表】【反转链表】(C语言)
    我的小站——半生瓜のblog(doraemon2.xyz)题目链接——206.反转链表-力扣(LeetCode)(leetcode-cn.com)反转链表思路一:反转指针。本质上就是调转指针的方向。首先我们......
  • 【链表】双向循环带头链表-增-删-查(C语言)
    我的小站——半生瓜のblog——同步更新单链表存在的缺陷:不能从后往前走,找不到他的前驱,指定位置删除增加尾删都要找前一个,时间复杂度都是O(n)针对上面的这些缺陷的解决......
  • 【链表】单链表-增-删-查(C语言)
    我的小站——半生瓜のblog单链表​​结构体定义​​​​打印​​​​创建结点​​​​尾插​​​​头插​​​​尾删​​​​头删​​​​查找​​​​在指定位置前插入某个......
  • 【线性表】之顺序表(C语言)
    【线性表】之顺序表​​线性表​​​​顺序表​​​​结构定义​​​​初始化​​​​销毁​​​​打印​​​​扩展空间​​​​尾插​​​​头插​​​​尾删​​​​头删......
  • LeetCode刷题(4)【移除元素&合并两个有序数组】(C语言)(含图解)
    移除元素典型双指针玩法。27.移除元素-力扣(LeetCode)(leetcode-cn.com)我们都会想到这样的解法:从前面依次往后推,是val就将该数据后面的元素依次覆盖上来,但是这样的时间复......
  • LeetCode刷题(5)【链表】【环形链表II】(C语言)
    环形链表I​​LeetCode刷题(3)【链表】【环形链表】&扩展_半生瓜のblog-CSDN博客​​环形链表II142.环形链表II-力扣(LeetCode)(leetcode-cn.com)这个题写起来不难,但是证......
  • 【线性表】之栈(C语言)
    栈​​回顾​​​​栈​​​​结构定义​​​​初始化​​​​销毁​​​​入栈​​​​出栈​​​​返回栈顶元素​​​​返回栈中元素个数​​​​判断栈是否为空​​​​......
  • 【线性表】之队列(C语言)
    队列​​队列的概念​​​​结构定义​​​​初始化​​​​销毁​​​​队尾入​​​​队头出​​​​队头出​​​​队头数据​​​​队尾数据​​​​是否为空​​​​返......
  • LeetCode刷题(7)【栈&队列】用队列实现栈(C语言)
    用队列实现栈225.用队列实现栈-力扣(LeetCode)(leetcode-cn.com)目的:用队列实现栈,从先进先出——>先进后出,1234这四个数据依次从队列1的队尾进入,要让4先出,一个队列是无法......