Pregunta

Lo único que quiero hacer es imprimir el contenido de readme.txt 20 veces .. por favor ayuda.

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;
}
¿Fue útil?

Solución

Esto hace que el hombre puestos de trabajo:

#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;
}

Otros consejos

hay varios problemas con su código. un primer momento no se ha inicializado. Segunda lectura del contenido del archivo debe hacerse una vez antes del bucle no después, debe imprimir el contenido del archivo en el que se imprime asdasd para ver el contenido del archivo impreso tantas veces como se ejecuta el bucle.

Usted debe hacer esto (pseudocódigo):

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

Editar De hecho, su verdadero problema es la variable i sin inicializar. La razón más profunda era que utilizó while donde for era más apropiado

De acuerdo con su código, vaya a imprimir asdasd si usted no está en el final del archivo.

tiene

int i;

y esto se i no inicializado.

if(!myfile.eof())

Es posible que desee perder el !. Usted está rebobinando hasta el principio del archivo en cada bucle.

(Kiril también tiene un punto de aquí ...)

#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;
}

No estoy seguro si esto soluciona el problema, pero su estructura es bastante malo. Utilice un tiempo cuando no se sabe cuántas veces se desea reproducir en bucle, de lo contrario utilizar un bucle. Algo parecido a continuación debe ser aceptable

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;
}

Espero que esto ayude.

No sé por qué quieres hacer eso, pero este código funciona:

#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;
 }

Si el archivo no está cambiando durante la iteración, esto es aún mejor

 #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;
 }
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top