使用fscanf函数可以去读文件中任意字符,使用变量参数%c即可。
1.fopen的函数原型:FILE * fopen(const char * path,const char * mode);
fopen函数的第一个参数是文件路径,第二个参数是打开方式,有以下几种方式:
r 以只读方式打开文件,该文件必须存在。
r+ 以可读写方式打开文件,该文件必须存在。
rb+ 读写打开一个二进制文件,允许读数据。
rw+ 读写打开一个文本文件,允许读和写。
w 打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失。若文件不存在则建立该文件。
w+ 打开可读写文件,若文件存在则文件长度清为零,即该文件内容会消失。若文件不存在则建立该文件。
a 以附加的方式打开只写文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾,即文件原先的内容会被保留。(EOF符保留)
a+ 以附加方式打开可读写的文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾后,即文件原先的内容会被保留。 (原来的EOF符不保留)
wb 只写打开或新建一个二进制文件;只允许写数据。
wb+ 读写打开或建立一个二进制文件,允许读和写。
wt+ 读写打开或着建立一个文本文件;允许读写。
at+ 读写打开一个文本文件,允许读或在文本末追加数据。
ab+ 读写打开一个二进制文件,允许读或在文件末追加数据。
上述的形态字符串都可以再加一个b字符,如rb、w+b或ab+等组合,加入b 字符用来告诉函数库打开的文件为二进制文件,而非纯文字文件。
返回值:文件顺利打开后,指向该流的文件指针就会被返回。如果文件打开失败则返回NULL,并把错误代码存在errno中。
2.例程:
#include
#define F_PATH "d:\\myfile\\file.dat"
char c;
int main(){
FILE*fp=NULL;//需要注意
fp=fopen(F_PATH,"r");
if(NULL==fp) return -1;//要返回错误代码
while(fscanf(fp,"%c",&c)!=EOF) printf("%c",c); //从文本中读入并在控制台打印出来
fclose(fp);
fp=NULL;//需要指向空,否则会指向原打开文件地址
return 0;
}
/*
1 88.33 2008122625 屈哲律 男 1990 91.00 79.00 95.00
2 84.33 2008122624 崔艺丹 女 1989 83.00 87.00 83.00
3 75.33 2008122628 戚桂兰 女 1990 74.00 79.00 73.00
4 74.67 2008122629 李秋丽 女 1991 71.00 90.00 63.00
5 71.67 2008122626 陈筑夏 女 1991 71.00 75.00 39.00
6 49.00 2008122627 陈伟 男 1989 66.00 51.00 30.00
Press any key to continue
*/
#include
struct student {
char name[20];
char sex[4];
unsigned id; // 学号
int birthyear;
float C_language;
float english;
float calculus; // 微积分
float average;
};
int main() {
int ranking,n = 0;
char buffer[100];
student a[100];
FILE *fin = fopen("data.txt","rt");
if(fin == NULL) {
printf("打开文件出错。\n");
return 1;
}
fgets(buffer,100 - 1,fin); // 读出第一行
while(!feof(fin)) {
fscanf(fin,"%d %f %u %s %s %d %f %f %f",
&ranking,
&a[n].average,
&a[n].id,
a[n].name,
a[n].sex,
&a[n].birthyear,
&a[n].C_language,
&a[n].english,
&a[n].calculus
);
printf("%d\t%6.2f %10u %10s %4s %6d %6.2f %6.2f %6.2f\n",
ranking,a[n].average,a[n].id,a[n].name,a[n].sex,a[n].birthyear,
a[n].C_language,a[n].english,a[n].calculus);
++n;
}
fclose(fin);
return 0;
}
int main()
{
char buf[1024]={0};
fp =fopen("1.txt","rb+");
if(NULL == fp)
{
return -1;
}
//浪费第一行数据
if(NULL == fgets(buf,fp))
{
//无数据
return -1;
}
while(fgets(buf,fp) ! = NULL)
{
//分割buf到结构体中
//struct student *s = new struct student; //自己补全下
splitstrtobuf(buf, s);
//将s放入链表或提前声请较大数组存放;自己实现下;
}
//...自己实现下;
}
//读取文件空格以及制表符
void splitstrtobuf(const char *buf, struct student *s)
{
char *cur = buf;
char *space = buf;
//取第一个字符首
//取第一个字符串结尾
//移动到字符串结束或者空格或者制表符
while('\0' == *space || ' ' == *space || '\t' == space)
{
space++;
}
strcpy(s.no, cur, space-1 - cur); //自己计算一下
//取第二个字符串,获取到第二字符串首位置
cur=space;
//移动到字符串非空格,非制表符处
while('\0' != *cur && ' ' != *cur && '\t' != cur)
{
cur++;
}
space = cur;
//取第二字符结尾
//移动到字符串结束或者空格或者制表符
while('\0' == *space || ' ' == *space || '\t' == space)
{
space++;
}
strcpy(s.score, cur, space-1 - cur); //自己计算一下
//等等
//先依次写完, 成规律后, 精炼成小函数, 即能完成目标,加油
}
随机读取