用c++从txt文件中读入数字的问题

我打开一个文件,然后用while(!of.eof()){of>>num;},那个文件本来是空的,什么都没有,空格也没有,但它还是会读一个很奇怪的数字到num里面去,这是为什么呢?怎么样才能让它在文件为空时跳过这个循环呢?盼高手解答

使用fopen,fscanf函数可以实现从txt文件当中读取数字。

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<stdio.h>
#define F_PATH "d:\\myfile\\file.dat"
int c;
int main(){
    FILE*fp=NULL;//需要注意
    fp=fopen(F_PATH,"r");
    if(NULL==fp) return -1;//要返回错误代码
    while(fscanf(fp,"%d",&c)!=EOF) printf("%d",c); //从文本中读入数字并在控制台打印出来
    fclose(fp);
    fp=NULL;//需要指向空,否则会指向原打开文件地址    
    return 0;
}

温馨提示:内容为网友见解,仅供参考
第1个回答  推荐于2017-09-14
你那个奇怪的数字其实是 未初始化的num。
你把 num 初始化为 1 看看,是不是输出 1 了呢。

估计你的程序是这样子的:
int main()
{
ifstream in("c:\\abc.txt", ios::in);

int num; //未初始化

//cout << in.eof() << endl;
while(!in.eof()) {
in >> num;
cout << num << endl;
}

return 0;
}

至于判断是否空之后还是进入了循环,我的猜测是:
txt 文件本身有表示开始和结束的字符,这些标志的中间是正文内容。所以第一次判断为真。仅是猜测。

你可以直接这样用

while(in >> a)
cout << a << endl;

就不会出现问题了。本回答被提问者采纳
第2个回答  2009-03-28
假设c盘里的beyond.txt里有如下数字12 34 90 100
程序就会跳过空格读出数字,代码如下:多加点分啊。。呵呵
#include<fstream.h>
#include<iostream.h>
int main()
{
int num=0;
ifstream in("c:\\beyond.txt",ios::out);
if(!in)
{
cout<<"file open failed"<<endl;
}
while(in.good())
{
in>>num;
cout<<num<<" ";
}
cout<<endl;
return 0;
}
第3个回答  2009-03-28
如果不是num初始化的问题:
你先看看它是否进入了while里面,
虽然eof可以判断文件是否读到末尾,但它不知道是否现在读取的是否是最后一个值,所以需要判断两次 这是读文件时经常要用到的
while(of.eof()==0)
{
if(of.eof()!=0)
break;
of>>num;
}
相似回答