码迷,mamicode.com
首页 > 其他好文 > 详细

【C】文件读写问题

时间:2015-08-09 18:50:42      阅读:136      评论:0      收藏:0      [点我收藏+]

标签:c语言   文件   读写   算法   排序   

C语言对文件操作的部分有可能被考到,虽然比较冷门,但是还是有了解的必要的。

题目是这样的:有两个磁盘文件“c:\A.txt"与“c:\B.txt",各存放一行字母,要求把两个文件的信息合并,并且按字母顺序排列,输出到c:\C.txt中。比如:

在C盘中有:

技术分享

“c:\A.txt"中有字母如下:

技术分享

“c:\B.txt"中有字母如下:

技术分享

程序运行完之后,在C盘会多出一个c:\C.txt,里面的结果是这样:

技术分享

本题的代码如下:

#include<stdio.h>
#include<stdlib.h>
void main(){
	char s[80];
	char c;
	int i=1,j;
	FILE *fp;
	//A文件的读取
	if((fp=fopen("C:\\A.txt","r"))==NULL){
		printf("Can't open this file\n");
		exit(0);
	}
	while((c=fgetc(fp))!=EOF){//将A中的字符一个字符一个字符地读入到s[80]字符数组里面
		s[i]=c;
		i++;
	}
	//B文件的字符追加读取到s[80]字符数组里面
	if((fp=fopen("C:\\B.txt","r"))==NULL){
		printf("Can't open this file\n");
		exit(0);
	}
	while((c=fgetc(fp))!=EOF){
		s[i]=c;
		i++;
	}
	s[i]='\0';//读完文件,写完字符串封口是必不可少的
	//冒泡排序
	for(i=1;s[i]!='\0';i++){
		for(j=1;s[j]!='\0';j++){
			if((s[j]>s[j+1])&&(s[j+1]!='\0')){
				s[0]=s[j];
				s[j]=s[j+1];
				s[j+1]=s[0];
			}
		}
	}
	//打开C文件进行输出
	fp=fopen("C:\\C.txt","w+");
	for(i=1;s[i]!='\0';i++){//s[0]作为数据交换的临时空间
		fputc(s[i],fp);
	}
	fclose(fp);
}

这里的话,其实C语言对文件的操作也不难,虽然对文件操作的方式有多种,但是这样记住最基本的操作文件的方式即可。

比如,首先你要通过FILE* 声明一个文件指针。并且用fopen将这个指针指向要打开的文件。其中fopen后的第二个参数:

r为单纯的读取,

w+为覆盖写入,如果要求追加写入则为a+。

操作完文件之后需要用fclose方法清空这个文件指针。

通过文件指针对文件操作也容易,利用fgetc来获取文件中的一个字符,fputc向文件输出一个字符。

读取到字符一般存放到字符数组里面,进行进一步的操作,输出字符,则是对字符数组进行遍历,fputc的第二个参数为文件指针,指明要输出到文件。

版权声明:本文为博主原创文章,未经博主允许不得转载。

【C】文件读写问题

标签:c语言   文件   读写   算法   排序   

原文地址:http://blog.csdn.net/yongh701/article/details/47378071

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!