小樽C++ 单章⑨ 文件

目录

1.文件类型变量的定义与引用

1.1 文件的读写

1.2 fopen()版 (C专用)

1.3 文件输入输出流 (C++专用)


文件有两种保存方式:二进制文件、文本文件。例如存121这个数字。

二进制存储效率高,但是对我们不友好,对每个值都要变成二进制太难啦!那我们取简单的文件文本吧。文本形式可以用ASCII码翻译成文字,比较方便。信息学比赛输入输出都是文本形式的文件。

学习文件,我们一定要搞懂,创建文件,打开文件,读写文件,关闭文件。

1.文件类型变量的定义与引用

C++程序与文件缓冲区有两种方式打交道:流式和I/O方式。信息学竞赛中一般用流式文件操作,所以我们主要学流式,流式文件分两种类型:

  • stream类的流文件。
  • 文件指针FILE。

要导入库:#include<cstdio> 才能使用文件。

1.1 文件的读写

只读方式读取输入文件

格式:freopen(“文件名”,“r”,stdin);

写入方式读取输出文件

格式:freopen(“文件名”,“w”,stdout);

最后一定要 fclose关闭文件输入输出文件;

fclose(stdin);fclose(stdin);

freopen文件代码模版

   

freopen是支持scanf, printf, cin, cout; 等方法进行文件输入输出。

例子1.读取in.txt文件的数据,把它们的和保存到out.txt中;

分析:1.把文件代码模板先写; 2.求和的代码。

要在相关路径创建输入文件 in.txt。

#include<iostream>
#include<cstdio>
using namespace std;
int main(){	
	freopen("in.txt","r",stdin); //文件数据读取 
	freopen("out1.txt","w",stdout); //文件结果写入   
	int n,sum=0;
//	for(int i=1;i<=5;i++){ //for循环求和 
//		cin>>n;
//		sum += n;
//	}
	while(cin>>n){//while循环求和 
		sum += n;
	}
	cout<<sum;
	fclose(stdin); fclose(stdout);
	return 0;
} 

 可以发现上面代码,除了文件框架的模版,其它代码是求和运算的算式。

运行代码后会输出,freopen("out1.txt","w",stdout);  的 out1.txt 这个文件。

 

输出的结果会显示在out1.txt 那里。 神奇吧!!!


1.2 fopen()版 (C专用)

除了freopen这种读取文件方式,我们还有fopen方式读取文件。要用到文件指针FILE。

这个fopen()方法相比 freopen的话只支持scanf,printf; 进行文件的输入输出。

fopen文件代码模版

 例子2.排序sort。输入n个整数,进行升序排序。

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
int main(){
	FILE *fin,*fout;	
	fin = fopen("sort.txt","r"); 
	fout = fopen("out.txt","w");  
	int a[1000],n,sum=0;
	fscanf(fin,"%d",&n);
	for(int i=0;i<n;i++){
		fscanf(fin,"%d",&a[i]);
	}
	sort(a,a+n);
	for(int i=0;i<n;i++){
		fprintf(fout,"%d ",a[i]);
	}
	fclose(fin); fclose(fout);
	return 0;
} 

记得先定义sort.txt文件,如上图输入6个数,对6个整数进行排序!!。

可以发现这次的打开文件和关闭文件的操作代码是不一样的。


1.3 文件输入输出流 (C++专用)

 先导入库:#include<fstream>

文件代码模版

例子3.读取in.txt文件的数据,把它们的和保存到out.txt中;

分析:1.把文件代码模板先写; 2.求和的代码

#include<fstream>
#include<iostream>
using namespace std;
int main(){
	ifstream fin("in.txt");
	ofstream fout("out.txt");   
	int n,sum=0;
	while(fin>>n){//while循环求和 
		sum += n;
	}
	fout<<sum<<endl;
	fin.close(); fout.close();
	return 0;
} 

猜你喜欢

转载自blog.csdn.net/weixin_44775255/article/details/129402666