/ S de archivos en C ++
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;
}
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;
}