Manejo de Archivos duda!

Iniciado por Mr.Blue, 4 Mayo 2010, 04:31 AM

0 Miembros y 2 Visitantes están viendo este tema.

Mr.Blue

Bueno les comento, tengo una duda al usar archivos,  mi idea es generar un archivo y que en este se puedan intresar datos el tema es que cada ves que se ingresan nuevos datos los datos anteriores se borran reemplazandolos por los nuevos datos, como puedo hacer para q esto no pase? osea que mantenga estos datos y en un renglon aparte escriba estos nuevos datos.

Otra pregunta tmb que me esta pasando es que al guardar estos datos ademas de la imformacion que ingreso tambien se guardan caracteres que no fueron ingresados como por ejemplo, letras o simbolos %, $ no se si es porq faltaria limpiar algo o no,
en mi ejercicio de ejemplo utilizo una structura la cual contine cadenas de caracteres y a estas las ingreso todo con gets, ya q no puedo  usar printf ya que le una palabra en ves de una palabra.

Código (cpp) [Seleccionar]

struct datos {
char nombre [15];// nombre del usuario
char pass [6];//password del usuario
int main()
datos regin;
FILE *fichero;
FILE *pf; // apunta al archivo


pf=fopen ("C:\\users.txt","wb");

if (pf==NULL)
  {
printf ("ERROR DE LECTURA");
getch();
exit(1);
  }

  while (i!=0) {

printf ("\nINGRESE NOMBRE DE USUARIO:");
gets (regin.nombre);

printf ("\nINGRESE PASSWORD:");
gets (regin.pass);


una parrte del codigo en donde se muestra la structura, la apertura del archivo el ingreso de datos por si es de ayuda.

Littlehorse

Abrí el archivo en modo a (Append)

Saludos
An expert is a man who has made all the mistakes which can be made, in a very narrow field.

Mr.Blue

ajam ahi ta arreglado gracias
y por el tema de que los datos entrancon basura?

Littlehorse

Ni idea porque no se como estas implementando los ciclos, las lecturas, las escrituras, ni los tipos de datos. El código que pusiste fue de ejemplo (y por cierto con algunos errores) y no indica lo suficiente como para responderte eso.
Pone el código completo y lo vemos (pero si es demasiado largo, prueba depurandolo vos mismo)

Saludos!
An expert is a man who has made all the mistakes which can be made, in a very narrow field.

taul

mmm el code esta bastante mal escrito..pero te felicito por empezar con C es lo mas grande q hay "para mi"

algo asi estaria mejor escrito:


#include <stdio.h>
#include <stdlib.h>

struct datos { //extructura
char nombre [15];// nombre del usuario
char pass [6];//password del usuario
}regin;

int i=0;

int main(){
FILE *pf;
 
pf = fopen("C:\\users.txt","ab");

  if (pf==NULL){
     printf ("ERROR DE LECTURA");
     exit(1);
  }

    do{

       printf("\nINGRESE NOMBRE DE USUARIO:");
       scanf("%s",&regin.nombre);

       printf("\nINGRESE PASSWORD:");
       scanf("%s",&regin.pass);
       
        if(strlen(regin.nombre)>14 || strlen(regin.pass)>5){ //evitamos un overflow
            system("clear");
            printf("Nombre o Password muy largos\n");
            sleep(2);
            system("clear");
         }
           else{
           fprintf(pf,"usuario: %s\npass: %s\n\n",regin.nombre,regin.pass); /*escribimos en el archivo*/
           fclose(pf);  //y lo cerramos
           i++;
           }
           
         

    }while (i==0);
system("clear");
printf("usuario Registrado\n");
}




Saludos...Taul.

Littlehorse

Esa no es la mejor manera de evitar un overflow ya que por mas que lo chequees luego, el overflow sucede igual. En todo caso debería usar fgets para leer las cadenas o especificar la cantidad de caracteres en scanf. De cualquier manera es mejor utilizar fgets ya que la cantidad a leer se indica en los argumentos, lo cual es obviamente una ventaja.

Por otro lado, si utilizas estructuras y abrís el archivo en modo binario, es conveniente trabajarlo de esa forma (fwrite, fread, por ejemplo).

En cuanto al scanf, no debes utilizar el ampersand con cadenas. Seguramente en ese caso no de error, pero si lo daría si la memoria del array es reservada en forma dinámica.

Y como ultimo, las variables globales deben evitarse en la medida de lo posible (Lo cual aplica en el 99.9% de las veces)

Saludos!
An expert is a man who has made all the mistakes which can be made, in a very narrow field.

misterharry

Cita de: taul en  4 Mayo 2010, 08:03 AM
        if(strlen(regin.nombre)>14 || strlen(regin.pass)>5){ //evitamos un overflow
            system("clear");
            printf("Nombre o Password muy largos\n");
            sleep(2);
            system("clear");
         }

disculpa, pero que hace exactamente la funcion strlen()???
y sleep() en que libreria esta??? esta disponible para linux???
hago muchas preguntas??? XD
gracias por todas las ayudas
^^

Littlehorse

An expert is a man who has made all the mistakes which can be made, in a very narrow field.

taul

#8
si tenes razon se provoca el overflow igual...bueno che lo escribi al bardo recien.

seria mejor un

scanf("%14s",&regin.nombre);

tomaria solo los 14 primeros char...

con respecto al ab...puedes trabajarlo perfectamente con fprintf...acordate q no lo estamos leyendo simplemente escribimos en el.para poder utilizar fwrite..deberias crear un buffer+añadir todo a un buffer+escribir el buffer en el archivo esto es = a desperdiciar memoria al vicio.

si debes declarar dentro de main tiene razon Littlehorse..aparte te ahorara dolores de cabezas el dia de mañana.

misterharry strlen debuelve un valor int el cual contine la cantidad de caracteres q contiene un buffer....y sleep no me acuerdo pero creo q en stdio.h...si esta disponible para linux al igual que todas las func de la lib standar...en windows en vez de ingresar segundos debes ingresar ms.


saludos.

Littlehorse

#9
Ya se que se puede usar fprintf, pero en el caso de tratar el archivo en modo binario y estar utilizando estructuras, es preferible trabajarlo de esa forma.

Si vos guardas un nombre (15 caracteres, 15 bytes) mas un password (6 caracteres, 6 bytes) es exactamente lo mismo que guardar la estructura entera (21 bytes) con la diferencia que guardando la estructura no estas limitado estrictamente al acceso secuencial del archivo.

PD: sleep no es estándar.

Saludos!
An expert is a man who has made all the mistakes which can be made, in a very narrow field.