Ficheros C++

Iniciado por harlequinz, 3 Febrero 2011, 19:11 PM

0 Miembros y 1 Visitante están viendo este tema.

harlequinz

Hola, posteo poque ya no se que hacer...me he puesto a hacer este problema como indica en el codigo pero no me lee el fichero y nose porque puede ser, si algun alma caritativa le podria echar un vistazo al codigo se lo agradeceria ;)

Código (cpp) [Seleccionar]
#include <iostream>
#include <fstream>
#include <string>
using namespace std;

/* - Se quiere informatizar la gestión de una fábrica. En dicha fábrica se construyen n tipos
de componentes electrónicos que se venden a m empresas de montaje de ordenadores. La
información de cada producto fabricado es su código (tipo int), precio (tipo double) y
nombre (tipo string), dicha información se encuentra en un fichero llamado productos.txt.
Para cada empresa compradora se almacena su nombre, dirección (ambas tipo string) y teléfono
(tipo int), dicha información se encuentra en el fichero clientes.txt. Por otro lado se tiene
almacenada la información sobre las ventas, el número de productos de cada tipo que le compran
las diferentes empresas, fichero cantidades.txt. */

struct Producto {
int codigo;
double precio;
string nombre;
};

struct Cliente {
string nombre;
string direccion;
int telefono;
};

const int MAX=100;

/* - Módulo que lea desde el fichero productos.txt los datos de los productos
y los devuelva en un array, que lea desde el fichero compradores.txt los datos
de las empresas compradoras y los devuelva en un array y que lea desde el fichero
cantidades.txt la cantidad de cada tipo de producto comprado por cada empresa y
devuelva dicha información en una matriz de mxn donde cada fila representa una
de las empresas compradoras y cada columna un tipo de producto. Las dimensiones m
y n, se conocerán tras leer los primeros ficheros. El módulo debe también devolver
un valor de tipo lógico indicando si las lecturas se han realizado con éxito o no. */


bool leeFicheros (Producto v_prod[],int& m,Cliente v_compr[],int& n,int matrix[][MAX]){

ifstream entradaProductos ("productos.txt");
ifstream entradaCompradores ("compradores.txt");
ifstream entradaCantidades ("cantidades.txt");

if (!entradaProductos || !entradaCompradores || !entradaCantidades)
return false;
else {

m=0;

while (entradaProductos >> v_prod[m].codigo){
entradaProductos >> v_prod[m].precio;
getline(entradaProductos >> ws, v_prod[m].nombre);
m++;
}

n=0;

while (getline(entradaCompradores >>ws, v_compr[n].nombre)){
getline(entradaCompradores >> ws, v_compr[n].direccion);
entradaCompradores >> v_compr[n].telefono;
n++;
}

for (int i=0; i<m; i++)
for (int j=0; j<n; j++)
entradaCantidades >> matrix[i][j];

}return true;
}




int main(){

Producto v_prod[MAX];
Cliente v_compr[MAX];
int matrix[MAX][MAX];
int m,n;

if (leeFicheros (v_prod,m,v_compr,n,matrix)){
for (int i=0; i<0; i++)
cout << "Registros leidos (productos.txt):\n"<< "Codigo: " << v_prod[i].codigo <<endl << "Precio: " << v_prod[i].precio << endl << "Nombre: "<< v_prod[i].nombre<<endl;
}

else cout << "Error al abrir los archivos "<<endl;

}

Oblivi0n

#1
Donde tienes creados los ficheros?

Código (cpp) [Seleccionar]
while (entradaProductos >> v_prod[m].codigo){
entradaProductos >> v_prod[m].precio;
getline(entradaProductos >> ws, v_prod[m].nombre);
m++;
}

podrias usar algo asi:
Código (cpp) [Seleccionar]
while (!entradaproductos.eof()){
                        entradaProductos >> v_prod[m].codigo
entradaProductos >> v_prod[m].precio;
getline(entradaProductos >> ws, v_prod[m].nombre);
m++;
}


Eso esta bien? en la condicion del while has puesto una entrada de archivos, te compila asi?

Edu

Tendrian q estar en la misma carpeta donde esta el proyecto no?

Oblivi0n

Cita de: XXX-ZERO-XXX en  3 Febrero 2011, 20:15 PM
Tendrian q estar en la misma carpeta donde esta el proyecto no?

Segun lo tiene el definido si, pero obviamente ai formas de abrirlo en cualquier lado del hd

Sus fallos creo que estan en las condificiones de los bucles

harlequinz

#4
Gracias Oblivion por contestarme, pero el fallo creo que no esta en la condicion del while, ya que he hecho lecturas de ficheros en otras ocasiones y no me a dado problema, lo que pretende esa condicion es que mientras peda leer el primer string por ejemplo que lea el resto, de todas formas e provado lo de .eof() aunque ya compruebo la apertura de los ficheros al principio y sigue sin irme :S

Nose si puede ser del formato del archivo...ya que programo en Mac OS y tene un formato .txt pero no tendria k dar problema...nuse que pede ser

un saludo! ;)

darkvidhack

Hola, he mirado por encima el código y no hay ningun fallo aparente, puede ser poque no tengas bien los nombres de los ficheros en la carpeta del proyecto o algo por el estilo, ya que si te devuelve que no se pueden leer los ficheros, es porque alguno de ellos no se ha podido abrir, prueba a ir leyendo y mostrando lo que lees, pero en una función void sin return, para ver lo que se lee y lo que no, y así intentar localizar el fallo.

A todo esto, he hecho un ejercicio exactamente igual, pero con mas funciones, en un examen de practicas de mi universidad, de dónde lo has sacado si no te importa decirlo?

Un saludo ;)
live and let die

la duda es la base de todo conocimiento

3mp3z@ndo

Código (cpp) [Seleccionar]
if (leeFicheros (v_prod,m,v_compr,n,matrix)){
for (int i=0; i<0; i++)   // <----- DIRIA QUE EL FALLO LO TIENES AQUI
cout << "Registros leidos (productos.txt):\n"<< "Codigo: " << v_prod[i].codigo <<endl << "Precio: " << v_prod[i].precio << endl << "Nombre: "<< v_prod[i].nombre<<endl;
}


Creo que en ese for que te he marcado está el problema, la condición nunca se cumple
ya que i no es menor que 0 por lo que si no me equivoco al no ser verdadera la condicion finalizaria la sentencia for y su codigo no se ejecutaria.

Saludos

Garfield07

Cita de: 3mp3z@ndo en  4 Febrero 2011, 20:29 PM
Código (cpp) [Seleccionar]
if (leeFicheros (v_prod,m,v_compr,n,matrix)){
for (int i=0; i<0; i++)   // <----- DIRIA QUE EL FALLO LO TIENES AQUI
cout << "Registros leidos (productos.txt):\n"<< "Codigo: " << v_prod[i].codigo <<endl << "Precio: " << v_prod[i].precio << endl << "Nombre: "<< v_prod[i].nombre<<endl;
}


No he leido el resto del code, pero te recuerdo que el if se hace si el resultado es 1... Y si en vez de true y false pones lo que es? Si no, borra partes del code, hasta reducirlo y saber donde te falla. Prueba a ver si con el mismo code puedes abrir un archivo y escribir algo... Asi sabras donde esta el fallo :P


* Quiero cambiar el mundo, pero estoy seguro de que no me darían el código fuente.
* No estoy tratando de destruir a Microsoft. Ese será tan solo un efecto colateral no intencionado.
* Si compila esta bien, si arranca es perfecto.

¡Wiki elhacker.net!
Un saludo

Edu

Sagrini creo q ya encontraron el fallo y lo dijieron, y lo del if no entiendo porq dices q haga eso :S

Garfield07

Cita de: XXX-ZERO-XXX en  4 Febrero 2011, 22:13 PM
Sagrini creo q ya encontraron el fallo y lo dijieron, y lo del if no entiendo porq dices q haga eso :S
Costumbre. Su code me confunde :P si que me duermo...

Cita de: harlequinz en  4 Febrero 2011, 00:04 AM
Gracias Oblivion por contestarme, pero el fallo creo que no esta en la condicion del while, ya que he hecho lecturas de ficheros en otras ocasiones y no me a dado problema, lo que pretende esa condicion es que mientras peda leer el primer string por ejemplo que lea el resto, de todas formas e provado lo de .eof() aunque ya compruebo la apertura de los ficheros al principio y sigue sin irme :S

Nose si puede ser del formato del archivo...ya que programo en Mac OS y tene un formato .txt pero no tendria k dar problema...nuse que pede ser
¿Seguro que se ha resuelto? Me has dicho dos veces que estoy dormido, falta de lectura; creo...


* Quiero cambiar el mundo, pero estoy seguro de que no me darían el código fuente.
* No estoy tratando de destruir a Microsoft. Ese será tan solo un efecto colateral no intencionado.
* Si compila esta bien, si arranca es perfecto.

¡Wiki elhacker.net!
Un saludo