файл ввода / вывода в C ++ - PullRequest
2 голосов
/ 17 ноября 2010

все, что я хочу сделать, это напечатать содержимое файла readme.txt 20 раз .. пожалуйста, помогите.

int main()
{
        ifstream myfile;
        string line;
        int i;
        myfile.open ("readme.txt");

        if (myfile.is_open()){
                while (i<20){
                        i++;
                        if(!myfile.eof()){
                                cout << "asdasd" << "\t";
                                myfile.seekg(0, ios::beg);
                        }
                        getline (myfile,line);
                        cout << line << endl;
                }
                cout << endl;
                myfile.close();
        }
        else cout << "Unable to open file";
        return 0;
}

Ответы [ 9 ]

1 голос
/ 17 ноября 2010

Это делает работу человек:

#include <iostream>
#include <vector>
#include <fstream>

int main()
{
 std::ifstream myfile;
 std::string content;
 std::string line;
 myfile.open ("Readme.txt");

 if (myfile.is_open()){

  if(!myfile.eof())
  {
   getline (myfile,line);      
   content.append(line);
  }

  while (!myfile.eof()){
   getline (myfile,line);   
   content.append("\n");
   content.append(line);
  }

  myfile.close();

  for(int i = 0; i < 20; i++)
   std::cout << content << std::endl;
 }
 else std::cout << "Unable to open file";
 return 0;
}
1 голос
/ 17 ноября 2010

Есть несколько проблем с вашим кодом. Сначала я не инициализирован. Второе чтение содержимого файла должно быть выполнено один раз перед циклом, а не после, вы должны напечатать содержимое файла, в котором печатается asdasd, чтобы просмотреть содержимое файла, напечатанное столько раз, сколько выполняется цикл.

0 голосов
/ 17 ноября 2010

Я не знаю, почему вы хотите это сделать, но этот код работает:

#include <iostream> 
#include <fstream>
using std::cout;
using std::endl;

int main(int argc,char* argv[])
{
    std::fstream myfile;
    for (int i=0; i<20; i++)
    {    
        myfile.open("main.cpp",std::fstream::in);
        if (myfile)
        {
           cout << myfile.rdbuf() << endl;
           cout << "FINISH" << endl;
        }
        else
           cout << "Error" << endl;
        myfile.close();
     }
     return 0;
 }

Если файл не изменяется во время итерации, это даже лучше

 #include <iostream>
 #include <fstream>

 using std::cout;
 using std::endl;

 int main(int argc,char* argv[])
 { 
    std::fstream myfile;
    myfile.open("main.cpp",std::fstream::in);
    for (int i=0; i<20; i++)
    {    
        if (myfile)
        {
            cout << myfile.rdbuf() << endl;
            cout << "FINISH" << endl;
        }
        else
            cout << "Error" << endl;
    }
    myfile.close();
    return 0;
 }
0 голосов
/ 17 ноября 2010

Не уверен, что это решит вашу проблему, но ваша структура довольно плохая. Используйте некоторое время, когда вы не знаете, сколько раз вы хотите выполнить цикл, в противном случае используйте цикл for. Что-то вроде ниже должно быть в порядке

int main()
{
    ifstream myfile;
    string content;
    string line;
    myfile.open ("readme.txt");
    while(!myfile.eof()){
            getline (myfile,line);
            content += line;
    }
    myfile.close();

    for(int i = 0; i < 20; i++)
    {
            cout << content << endl;
    }

    return 0;
}

Надеюсь, это поможет.

0 голосов
/ 17 ноября 2010
#include <iostream>
#include <algorithm>
#include <fstream>
#include <iterator>
#include <vector>

int main ()
{
    std::ifstream ifs("readme.txt");
    std::vector<char> filebuffer;

    ifs.seekg (0, std::ios::end);
    size_t size = static_cast<size_t>(ifs.tellg());
    ifs.seekg (0, std::ios::beg);

    filebuffer.resize(size);
    ifs.read(&filebuffer[0], size);

    for(int i = 0; i < 20; ++i)
        std::copy(filebuffer.begin(), filebuffer.end(),
            std::ostream_iterator<char>(std::cout));

    return 0;
}
0 голосов
/ 17 ноября 2010
if(!myfile.eof())

Возможно, вы захотите потерять !. Вы перематываете начало файла в каждом цикле.

(у Кирилла тоже есть точка ...)

0 голосов
/ 17 ноября 2010

У вас есть

int i;

, и это i не инициализировано.

0 голосов
/ 17 ноября 2010

Согласно вашему коду, вы печатаете asdasd, если вы НЕ в конце файла.

0 голосов
/ 17 ноября 2010

Вы должны сделать это (псевдокод):

if(file is open)
{
   for(int i = 0; i<20; ++i)
   {
     while(getline(file, line))
     {
       print line
     }
     seek to 0
   }
   close file
}

Редактировать: На самом деле ваша настоящая проблема - неинициализированная переменная i.Более глубокая причина была в том, что вы использовали while, где for было более подходящим

...