probleme de modification de fichier texte urgent - C - Programmation
Marsh Posté le 16-06-2004 à 11:31:43
scanf("%s",&name);//saisie d'une chaine (s pour string)
première ligne première erreur. et je ne te parle pas de remplacer scanf par fgets
printf ("que voulez vous modifiez :\n\n" );
printf("\n1 Modifier le nom" );
printf("\n2 Modifier le prenom" );
printf("\n3 Modifier la date de naissance " );
printf("\n4 Modifier l'adresse" );
printf("\n5 Modifier le code postal" );
printf("\n6 Modifier la ville" );
printf("\n7 Modifier le numero de telephone 1" );
printf("\n8 Modifier le numero de telephone 2" );
printf("\n9 Modifier le numero de portable" );
printf("\n10 Modifier le numero de fax" );
printf("\n11 Modifier l'e-mail 1" );
printf("\n12 Modifier l'e-mail 2" );
printf("\n13 Modifier le role" );
printf("\n14 Modifier le statut" );
printf("\n15 Modifier les remarques " );
un seul printf suffit
printf("ligne1\n"
"ligne2\n"
etc
le cpp colle toutes les lignes
Marsh Posté le 16-06-2004 à 11:32:37
fflushall() n'est pas standard. préfère fflush(stdout);
et y a pas de booléen en C
Marsh Posté le 16-06-2004 à 11:36:45
elle est ou la faute a la premiere ligne?g mis %s c bon non?
si le truc booleen marche
puis pour la lisibilite g prefere ma solution pr le printf que celle sur une seul ligne.
bon en plus en c je debute donc bon on passe ca,moi mon pb c le gets ki me fait retourner a mon menu alors ki devrait saisir
Marsh Posté le 16-06-2004 à 11:46:47
- si c'est pas le %s qui déconne, c'est que ça doit être à côté non ?
- bravo, tu utilises VC++
- la solution que je te propose est plus lisible, car tu économises des tas de "printf( );"
Marsh Posté le 16-06-2004 à 11:50:52
non car sa marche avec scanf
on ma parle de stdin
je v tester
et moi j'utilise sutout borland mais bon si je doit utiliser vsc++
c po grave
Marsh Posté le 16-06-2004 à 12:00:34
mais vla le boulet ca marche mais pas avec les espace c tout
Marsh Posté le 16-06-2004 à 12:09:46
bon ecoutez arreter ede me parler de mon printf ou mon scanf, je veut juste prendre en compte les espaces merci de vous focaliser sur ca et non les pb booleen, ca fait deja une semaine ke je bosse sur cette erreur je suis a bout la!!!!!
Marsh Posté le 16-06-2004 à 12:16:26
ben tu vas continuer tout seul alors ... puisque tu ne veux pas écouter nos conseils
Marsh Posté le 16-06-2004 à 12:17:09
lefauve a écrit : mais vla le boulet ca marche mais pas avec les espace c tout |
c'est vrai que t'as vachement d'expérience. je crois qu'en 30minutes, tout le monde peut en avoir autant
Marsh Posté le 16-06-2004 à 12:28:22
non mais je critique pas vos connaisance mais bon je vs pose une question présice et vs me parlez de la mise en page ou des reponses a coté donc bon c normal ke sa me saoul c t pas pr vs vexer les gars
Marsh Posté le 16-06-2004 à 12:40:33
on te dis que 1) ton scanf marche pas et plante 2) d'utiliser fgets 3) que les booléens existe pas en C
Marsh Posté le 16-06-2004 à 12:47:22
le scanf("%s",&name)?pk il marche pas, c chelou , moi il marche sur mon pc oui mais j'utilise c++ builder donc il reconnait le booléen puis je l'ait essayer , il marche, je sai je suis relou mais bon, a la limite explique moi pk ca marche pas ca m'interesse je sui ouvert a tt propos de toute facon
Marsh Posté le 16-06-2004 à 12:51:34
1) tu ferais bien de réviser tes pointeurs
2) "ça compile" ne veut pas dire "ça marche". Revois ton C
Marsh Posté le 16-06-2004 à 12:56:20
il est ou le probleme avec le pointeur?le programme se compile et fonctionne si je remplace le gets par scanf donc j'en ai deduit ke c t pas le scanf donc au lieu de me faire des critique gratuite explique moi ca sera plus rapide merci taz
Marsh Posté le 16-06-2004 à 12:58:49
a la limite corrige le pg et balance ta soluce ca m'avancera
Marsh Posté le 16-06-2004 à 13:54:49
utilise comme ça
char ligne[128];
fgets(ligne, sizeof ligne, stdin)
Marsh Posté le 16-06-2004 à 15:12:55
et apres , je fait koi?je l'attribu a l'enregistrement en fonction du choix?
Marsh Posté le 16-06-2004 à 15:40:42
faut ke je redeclare tout les enregistrement?ou je peut mettre ce qui sont dans ma structure?
Marsh Posté le 16-06-2004 à 15:58:45
bah je veut gerer des equipe, pouvoir en ajouter, en supprimer, en rechercher et en modifier et tout garder sur un fichier txt.donc g fait ca:
FILE *fichier_equipe;
struct equipe
{
char nom[50+1];
char prenom[50+1];
char naissance[15+1];
char adresse [40 +1];
char cp[12+1];
char ville [50+1];
char tel1[12+1];
char tel2[12+1];
char portable[12+1];
char fax[12+1];
char email1[55+1];
char email2[55+1];
char role [40+1];
char statut[40+1];
char remarque[100+1];
}enrequipe;
ensuite j'ajoute l'equipe comme ca:
void ajoutequipe ()
{
char rep;
rep='o';
do
{
printf ("enregistrer une équipe?" );
flushall();
rep = (char) getchar();
if ((rep == 'o') || (rep == 'O'))
{
fichier_equipe = fopen("fequipe.txt","a+" );
printf("saisir le nom de l'equipe:\n" );
flushall();
gets(enrequipe.nom );//nom de l'enregistrement.le champ
printf ("saisir prenom: " );
flushall();
gets(enrequipe.prenom);
printf ("saisir la date de naissance: " );
flushall();
gets(enrequipe.naissance);
printf ("saisir l'adresse: " );
flushall();//afin de liberer la memoire tampon
gets(enrequipe.adresse);
printf("saisir le code postal :\n" );
flushall();
gets(enrequipe.cp);
printf ("saisir la ville :\n" );
flushall();
gets(enrequipe.ville);
printf ("saisir le telephone 1: " );
flushall();
gets(enrequipe.tel1);
printf ("saisir le telephone 2: " );
flushall();
gets(enrequipe.tel2);
printf ("saisir le numero de portable :\n" );
flushall();
gets(enrequipe.portable);
printf("saisir le numero de fax :\n" );
flushall();
gets(enrequipe.fax);
printf("saisir l'e-mail 1 :\n" );
flushall();
gets(enrequipe.email1);
printf("saisir l'e-mail 2 :\n" );
flushall();
gets(enrequipe.email2);
printf("saisir le statut : \n" );
flushall();
gets(enrequipe.statut);
printf("saisir son role :\n" );
flushall();
gets(enrequipe.role);
printf("saisir des remarques :" );
flushall();
gets(enrequipe.remarque);
fwrite (&enrequipe,sizeof(enrequipe),1,fichier_equipe);
fclose (fichier_equipe);
}
else
{
system("cls" );//appelle la fonction du systeme ki
menuequipe();//on retourne au menu des clients
}
}while((rep=='o')|| (rep == 'O'));//condition du fr tque
}
puis apres je veut modifier une ligne dans l'equipe, bah j'utilise ma fonction modifier du premier truc mais bon tjs le meme problem, kan je saisi le choix qui se rapport a l'information que je veut modifier par exemple l'adresse (enrequipe.adresse) si je saisi avec scanf,ca prend pas en compte les espaces, le gets il le reconnait plus, et je sait pas comment utiliser fgets dans ce cas si.je te parle de la synthaxe exact bien sur.
Marsh Posté le 16-06-2004 à 16:00:19
ReplyMarsh Posté le 16-06-2004 à 16:04:03
1) n'utilise pas flushall mais fflush(stdout)
2) utilise fgets à la place de gets. je t'ai donné un exemple. fgets(structurre.membre, sizeof structurre.membre, stdin)
Marsh Posté le 16-06-2004 à 16:04:48
alors g modifier comme ca, ca marche mieux car ta soluce seul ne m'aider pas elle faisait la meme que le gets
donc j'ai mis au-dessus et en-dessous fflush(stdin)
donc ca avnce puisque ca enregistre mais moi je voulait qu'il le mette a la place,maintenant j'ai le fichier en double il est ou le pb?
Marsh Posté le 16-06-2004 à 16:11:29
bon ben alors ça marche.
J'AI PAS DIT fflush(stdin)
MAIS fflush(stdout)
fflush(stdin) ne fait rien et rien du touts
Marsh Posté le 16-06-2004 à 16:18:49
bah sur mon pg c le contraire mais maintenant je me retrouve avec enregistrement l'original et le modifier
Marsh Posté le 16-06-2004 à 16:34:53
bon quand tu sauras t'exprimer, t'auras qu'à remonter ce sujet
et me dit pas "ouin c'est le contraire" je suis pas là pour te raconter des conneries. si ça foire, c'est pas là, c'est en amont dans ton programme
des printf + fflush(stdout) + fgets c'est une solution éprouvée depuis 20ans, tu vas pas nous dire que ça marche pas après une après midi de C
Marsh Posté le 16-06-2004 à 16:49:48
BOn ecoute je ne fait que te dire ce qui se passe sur mon pc, j'en sait rien si c normal ou pas normal, que stdin marche mais ce que je sai c ke ta solution na pas d'effet dans mon programme donc pas la peine de t'enerver ou alors tu je l'ai juste mal place dans cette partis de mon code.en plus je sai pas pk tu me parle de printf la.
donc je l'ai place ici:
case 3:fflush(stdout);
fgets(enrequipe.adresse,150,stdin);
break;
CA sa marche pas ensuite
case 3:fflush(stdout);
fgets(enrequipe.adresse,150,stdin);
fflush(stdout);
break;
ca non plus
case 3:
fgets(enrequipe.adresse,150,stdin);
fflush(stdout);
break;
ca non plus.le seul truc ki fait qqch,c'est
case 3:
fflush(stdin);
fgets(enrequipe.adresse,150,stdin);
fflush(stdin);
break;
c tout!!!j'y peut rien je v pas te dire ca marche alors que non.donc est-ce que je l'ai bien place ton fflush()
?
Marsh Posté le 16-06-2004 à 16:53:01
Retire vite tes fflush(stdin) avant de te faire insulter.
Extrait de http://www.isty-info.uvsq.fr/~rume [...] 4.html#q_4 mais surtout présent dans le Kernighan & Ritchie :
14.4 Pourquoi ne jamais faire fflush(stdin) ?
La fonction fflush() a un comportement défini uniquement sur les flux ouverts en écriture tels que stdout. Il est possible que sur votre système, appliquer cette fonction à stdin soit possible, mais c'est alors une extension non standard. Le comportement est indéterminé, et imprévisible.
Marsh Posté le 16-06-2004 à 16:54:13
ase 3:fflush(stdout);
fgets(enrequipe.adresse,150,stdin);
break;
ça marchera toujours sauf si avant t'as foutu le bronx avec tes flush à la con dans tous les sens, résultat, ton stdin est une vrai poubelle, y a de tout dedans.
alors tu vérifies toutes tes lectures en amont, tu fais bien des printf + fflush(stdout) + scanf/fgets, tu vérifies que scanf et fgets on bien réussi et ça marchera.
Marsh Posté le 16-06-2004 à 11:29:35
donc dans les procedure de modification modifequipe
lorsque je demande quelles informations voulez vous modifier, je saisis un chiffre en fonction de l'info, puis je saisi l'information a laquelle il se rapporte .
Mais pour certaines informations g besoin d'utiliser les espaces, j'ai donc utilisé gets(enregistrement.champ) malheureusement je sais pas pourquoi mais il le reconnait pas ,g essayer scanf pr voir si je ne m'etait pas tromper autre part dans la selection et cela fonctionne mais je ne peut alors pas utiliser les espaces.donc ou j'utilise mal la synthaxe du gets ou le pb vient d'autre part.Je vous en serais reconnaissant si vous pouviez y jeter un coup d'oeil pour me renseigner merci d'avance