C/C++读写文本文件、二进制文件「建议收藏」

C/C++读写文本文件、二进制文件「建议收藏」C语言文本文件读写方式;C语言二进制文件读写方式;CPP文本文件读写方式;CPP二进制文件读写方式;

大家好,又见面了,我是你们的朋友全栈君。

一:目的

掌握C语言文本文件读写方式;
掌握C语言二进制文件读写方式;
掌握CPP文本文件读写方式;
掌握CPP二进制文件读写方式;

二:C语言文本文件读写

1. 文本文件写入

//采用C模式对Txt进行写出
void TxtWrite_Cmode()
{
	//准备数据
	int index[50] ;
	double x_pos[50], y_pos[50];
	for(int i = 0; i < 50; i ++ )
	{
		index[i] = i;
		x_pos[i] = rand()%1000 * 0.01 ;
		y_pos[i] = rand()%2000 * 0.01;
	}
	//写出txt
	FILE * fid = fopen("txt_out.txt","w");
	if(fid == NULL)
	{
		printf("写出文件失败!\n");
		return;
	}
	for(int i = 0; i < 50; i ++ )
	{
		fprintf(fid,"%03d\t%4.6lf\t%4.6lf\n",index[i],x_pos[i],y_pos[i]);
	}
	fclose(fid);
}

2. 文本文件读取

//采用C模式对Txt进行读取
void TxtRead_Cmode()
{
	FILE * fid = fopen("txt_out.txt","r");
	if(fid == NULL)
	{
		printf("打开%s失败","txt_out.txt");
		return;
	}
	vector<int> index;
	vector<double> x_pos;
	vector<double> y_pos;
	int mode = 1;
	printf("mode为1,按字符读入并输出;mode为2,按行读入输出;mode为3,知道数据格式,按行读入并输出\n");
	scanf("%d",&mode);
	if(mode == 1)
	{
		//按字符读入并直接输出
		char ch;       //读取的字符,判断准则为ch不等于结束符EOF(end of file)
		while(EOF!=(ch= fgetc(fid)))
			 printf("%c", ch); 
	}
	else if(mode == 2)
	{
		char line[1024];
		memset(line,0,1024);
		while(!feof(fid))
		{
			fgets(line,1024,fid);
			printf("%s\n", line); //输出
		}
	}
	else if(mode == 3)
	{
		//知道数据格式,按行读入并存储输出
		int index_tmp;
		double x_tmp, y_tmp;
		while(!feof(fid))  
		{  
			fscanf(fid,"%d%lf%lf\n",&index_tmp, &x_tmp, &y_tmp);
			index.push_back(index_tmp);
			x_pos.push_back(x_tmp);
			y_pos.push_back(y_tmp);
		}
		for(int i = 0; i < index.size(); i++)
			printf("%04d\t%4.8lf\t%4.8lf\n",index[i], x_pos[i], y_pos[i]);

	}
	fclose(fid);
}

三:C语言二进制文件读写

1. 二进制文件写入

//采用C模式写二进制文件
void DataWrite_CMode()
{
	//准备数据
	double pos[200];
	for(int i = 0; i < 200; i ++ )
		pos[i] = i ;
	//写出数据
	FILE *fid;
	fid = fopen("binary.dat","wb");
	if(fid == NULL)
	{
		printf("写出文件出错");
		return;
	}
	int mode = 1;
	printf("mode为1,逐个写入;mode为2,逐行写入\n");
	scanf("%d",&mode);
	if(1==mode)
	{
		for(int i = 0; i < 200; i++)
			fwrite(&pos[i],sizeof(double),1,fid);
	}
	else if(2 == mode)
	{
		fwrite(pos, sizeof(double), 200, fid);
	}
	fclose(fid);
}

2.二进制文件读取


//采用C模式读二进制文件
void DataRead_CMode()
{
	FILE *fid;
	fid = fopen("binary.dat","rb");
	if(fid == NULL)
	{
		printf("读取文件出错");
		return;
	}
	int mode = 1;
	printf("mode为1,知道pos有多少个;mode为2,不知道pos有多少个\n");
	scanf("%d",&mode);
	if(1 == mode)
	{
		double pos[200];
		fread(pos,sizeof(double),200,fid);
		for(int i = 0; i < 200; i++)
			printf("%lf\n", pos[i]);
		free(pos);
	}
	else if(2 == mode)
	{
		//获取文件大小
		fseek (fid , 0 , SEEK_END);       
		long lSize = ftell (fid);  
		rewind (fid); 
		//开辟存储空间
		int num = lSize/sizeof(double);
		double *pos = (double*) malloc (sizeof(double)*num);  
		if (pos == NULL)  
		{  
			printf("开辟空间出错");   
			return; 
		} 
		fread(pos,sizeof(double),num,fid);
		for(int i = 0; i < num; i++)
			printf("%lf\n", pos[i]);
		free(pos);     //释放内存
	}
	fclose(fid);
}



四:C++文本文件读写

1. 文本文件写入

//采用CPP模式写txt
void TxtWrite_CPPmode()
{
	//准备数据
	int index[50] ;
	double x_pos[50], y_pos[50];
	for(int i = 0; i < 50; i ++ )
	{
		index[i] = i;
		x_pos[i] = rand()%1000 * 0.01 ;
		y_pos[i] = rand()%2000 * 0.01;
	}
	//写出txt
	fstream f("txt_out.txt", ios::out);
	if(f.bad())
	{
		cout << "打开文件出错" << endl;
		return;
	}
	for(int i = 0; i < 50; i++)
		f << setw(5) << index[i] << "\t" << setw(10) << x_pos[i] <<"\t" <<setw(10)<< y_pos[i] << endl;
	f.close();

}

2.文本文件读取

//采用CPP模式读取txt
void TextRead_CPPmode()
{
	fstream f;
	f.open("txt_out.txt",ios::in);	
	//文件打开方式选项:
	// ios::in    = 0x01, //供读,文件不存在则创建(ifstream默认的打开方式)
	// ios::out    = 0x02, //供写,文件不存在则创建,若文件已存在则清空原内容(ofstream默认的打开方式)
	// ios::ate    = 0x04, //文件打开时,指针在文件最后。可改变指针的位置,常和in、out联合使用
	// ios::app    = 0x08, //供写,文件不存在则创建,若文件已存在则在原文件内容后写入新的内容,指针位置总在最后
	// ios::trunc   = 0x10, //在读写前先将文件长度截断为0(默认)
	// ios::nocreate = 0x20, //文件不存在时产生错误,常和in或app联合使用
	// ios::noreplace = 0x40, //文件存在时产生错误,常和out联合使用
	// ios::binary  = 0x80  //二进制格式文件
	vector<int> index;
	vector<double> x_pos;
	vector<double> y_pos;
	if(!f)
	{
		cout << "打开文件出错" << endl;
		return;
	}
	cout<<"mode为1,按字符读入并输出;mode为2,按行读入输出;mode为3,知道数据格式,按行读入并输出"<<endl;
	int mode = 1;
	cin>>mode;
	if(1== mode)
	{
		//按字节读入并输出
		char ch;
		while(EOF != (ch= f.get()))
			cout << ch;
	}
	else if(2 == mode)
	{
		//按行读取,并显示
		char line[128];
		int numBytes;
		f.getline(line,128);
		cout << line << "\t" << endl ;
		f.getline(line,128);
		cout << line << "\t" << endl ;
		f.seekg(0,0);							//跳过字节
		//seekg(绝对位置);      //绝对移动,    //输入流操作
		//seekg(相对位置,参照位置);  //相对操作
		//tellg();					 //返回当前指针位置
		while(!f.eof())
		{
			//使用eof()函数检测文件是否读结束
			f.getline(line,128);
			numBytes = f.gcount();		//使用gcount()获得实际读取的字节数
			cout << line << "\t" << numBytes << "字节" << endl ;
		}
	}
	else if(3 == mode)
	{
		//如果知道数据格式,可以直接用>>读入
		int index_temp = 0;
		double x_pos_temp = 0, y_pos_temp = 0;
		while(!f.eof())
		{
			f >> index_temp >> x_pos_temp >> y_pos_temp ;
			index.push_back(index_temp);
			x_pos.push_back(x_pos_temp);
			y_pos.push_back(y_pos_temp);
			cout << index_temp << "\t" << x_pos_temp << "\t" << y_pos_temp << endl;
		}
	}
	f.close();
}

五:C++二进制文件读写

1. 二进制文件写入

//采用CPP模式写二进制文件
void DataWrite_CPPMode()
{
	//准备数据
	double pos[200];
	for(int i = 0; i < 200; i ++ )
		pos[i] = i ;
	//写出数据
	ofstream f("binary.dat",ios::binary);
	if(!f)
	{
		cout << "创建文件失败" <<endl;
		return;
	}
	f.write((char*)pos, 200*sizeof(double));      //fwrite以char *的方式进行写出,做一个转化
	f.close();
}

2.二进制文件读取

//采用CPP模式读二进制文件
void DataRead_CPPMode()
{
	double pos[200];
	ifstream f("binary.dat", ios::binary);
	if(!f)
	{
		cout << "读取文件失败" <<endl;
		return;
	}
	f.read((char*)pos,200*sizeof(double));
	for(int i = 0; i < 200; i++)
		cout << pos[i] <<endl;
	f.close();

}

六 总结

1. C语言读写文件均通过FILE指针执行操作,其中文本文件的读写用fprintf,fscanf,二进制文件的读写用fread,fwrite
2. C++读写文件通过fstream、ifstream、ofstream进行操作,文本文件用<< 和 >> 进行读写,二进制文件用read和write进行读写




版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/137562.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Apache中 RewriteCond 规则参数介绍[通俗易懂]

    Apache中 RewriteCond 规则参数介绍[通俗易懂]Apache中RewriteCond语句对于我来说一直是个难点,多次试图去把它搞明白,都没有结果,这次我终于算大概知道它的意思了。RewriteCond就像我们程序中的if语句一样,表示如果符合某个或某几个条件则执行RewriteCond下面紧邻的RewriteRule语句,这就是RewriteCond最原始、基础的功能,为了方便理解,下面来看看几个例子。RewriteEngineonRewriteCond%{HTTP_USER_AGENT}^Mozilla\/5\.0.*Rew…

    2022年6月10日
    27
  • springboot实现热部署

    springboot实现热部署文章目录前言原理方式开始配置在pom.xml中添加依赖devtools的配置IDEA中配置测试参考资料&小结小结参考资料前言在实际开发过程中,每次修改代码就得将项目重启,重新部署,对于一些大型应用来说,重启时间需要花费大量的时间成本。对于一个后端开发者来说,重启过程确实很难受啊。在Java开发领域,热部署一直是一个难以解决的问题,目前的Java虚拟机只能实现方法体的修改热部署,…

    2022年5月23日
    41
  • 51单片机rc522程序_51单片机usb驱动

    51单片机rc522程序_51单片机usb驱动最近在某宝上买了一块RC522模块,试玩了下,读写卡正常。想学习使用新的东西时,有必要了解它的工作原理和工作过程,不清楚或者不知道的可以参考相关数据手册和参考文献,在这里为了节省自己的时间,我只对我的51程序做一个小小的笔记~~想要驱动RC522模块对IC卡(这里用的是M1卡型号是S50)进行读写操作,一定要有以下5个步骤:一、寻卡二、防冲突三、选择卡四、验证扇区密码(每个扇区都有密匙A…

    2022年9月18日
    0
  • FreeSync是什么

    FreeSync是什么FreeSync由AMD开发,是一种动态刷新率功能,通过嵌入式和外部DisplayPort面板实现,部分AMDGPU中的FreeSync技术解决了处理器和显示器之间的通信问题,消除了图像撕裂和波动,从而轻松实现流畅的游戏体验。于2014年首次宣布与Nvidia的专有G-Sync竞争。AMD已与VESA(视频电子标准协会)合作,将DisplaySync的支持添加到DisplayPort1.2a标准,以及后来的HDMI,然后将其用于FreeSync技

    2022年6月10日
    280
  • java messagedigest_JAVA MessageDigest(MD5加密等)

    java messagedigest_JAVA MessageDigest(MD5加密等)转自http://blog.csdn.net/hudashi/article/details/8394158一、概述java.security.MessageDigest类用于为应用程序提供信息摘要算法的功能,如MD5或SHA算法。简单点说就是用于生成散列码。信息摘要是安全的单向哈希函数,它接收任意大小的数据,输出固定长度的哈希值。关于信息摘要和散列码请参照《数字证书简介》MessageD…

    2022年6月16日
    24
  • laravel-admin新手的使用

    laravel-admin新手的使用

    2021年10月21日
    35

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号