从文件读取数据,文件名作为输入

时间:2009-06-14 08:54:34

标签: c++

我正在编写一个程序,它从不同的文件中读取数据,这些文件作为输入字符串给出,并将它们存储到矢量矢量中。问题我无法调试读取不同文件的循环。我关闭了ifstream对象,使用空函数清除了字符串...但是当我给第二个文件名作为输入时它仍然会终止。

我正在复制代码供您阅读。它是另一个函数调用的函数。 Transposectr转置矩阵。

的代码:

vector<vector<float> > store1,store2;
ifstream bb;

string my_string;

float carrier;
vector<float> buffer;

cout<<"enter the file name"<<endl;
getline(cin,my_string);

while (my_string!="end")
{

    bb.open(my_string.c_str());
    while (!bb.eof())
    {
        bb >> carrier;

        if (bb.peek() == '\n' || bb.eof() )
        {
            buffer.push_back(carrier);
            store1.push_back(buffer);
            buffer.clear();
        }

        else
        {
            buffer.push_back(carrier);
        }


    }

    bb.close();
    buffer.clear();
    transposectr1(store1);
    storex.push_back(store1[1]);
    storey.push_back(store1[0]);
    store1.clear();
    my_string.empty();
    cout<<"done reading the file"<<endl;
    cout<<"enter the file name"<<endl;
    getline(cin,my_string);
}

3 个答案:

答案 0 :(得分:3)

我真的不清楚你想要做什么。但是在使用istreams时我有一个金色的ruile:

永远不要使用eof()函数!

几乎可以肯定的是,你没有做到你认为它做的事情。相反,您应该测试读取操作是否成功。

int x;

while( in >> x ) {
   // I read something successfully
}

你可能也想避免偷看()。尝试使用此建议重新编写代码。

答案 1 :(得分:0)

添加

bb.clear();
在bb.close()之后你可能会得到正确的结果。我认为bb.close()不会重置光标。

答案 2 :(得分:0)

Neil Butterworth是对的

  

永远不要使用eof()函数!

This link解释了原因。