Comment faire une boucle dans un sscanf ?
Fermé
geekat
Messages postés
228
Date d'inscription
vendredi 31 juillet 2015
Statut
Membre
Dernière intervention
24 février 2017
-
Modifié par geekat le 31/01/2016 à 14:35
geekat Messages postés 228 Date d'inscription vendredi 31 juillet 2015 Statut Membre Dernière intervention 24 février 2017 - 8 févr. 2016 à 15:15
geekat Messages postés 228 Date d'inscription vendredi 31 juillet 2015 Statut Membre Dernière intervention 24 février 2017 - 8 févr. 2016 à 15:15
A voir également:
- Comment faire une boucle dans un sscanf ?
- Le fichier contient un programme écrit en python. le programme construit un mot secret mais il ne l'affiche pas. modifiez ce programme afin que à chaque itération de la boucle : la variable a augmente de 2 la variable b diminue de 1 ajoutez une instruction pour faire afficher le mot secret construit. quel est ce mot secret ? ✓ - Forum Python
- Pc s'allume et s'éteint en boucle - Forum Matériel informatique
- Boucle cmd - Forum Programmation
- Freebox redémarre en boucle ✓ - Forum Freebox
- Boucle excel sans macro - Forum Excel
2 réponses
[Dal]
Messages postés
6057
Date d'inscription
mercredi 15 septembre 2004
Statut
Contributeur
Dernière intervention
17 mars 2023
1 043
Modifié par [Dal] le 1/02/2016 à 12:48
Modifié par [Dal] le 1/02/2016 à 12:48
Salut geekat,
Peux-tu donner un exemple de ce qui figure dans "chaine" ?
Dans ton premier code, tu mets "%lf ,%lf ,%lf ,%lf", alors que dans le second, il n'y a pas d'espace suivi d'une virgule de consommés dans la lecture faite par sscanf.
Par ailleurs, si tu sais qu'il en a 4, je ne vois pas pourquoi le premier code ne serait pas "optimisé", surtout compte tenu de ce que tes caractères séparateurs, bien que bizarres (un espace suffit, non ?), sont pris en charge.
Si les valeurs n'étaient séparées que par un espace, le 2ème code fonctionnerait probablement.
Dal
Peux-tu donner un exemple de ce qui figure dans "chaine" ?
Dans ton premier code, tu mets "%lf ,%lf ,%lf ,%lf", alors que dans le second, il n'y a pas d'espace suivi d'une virgule de consommés dans la lecture faite par sscanf.
Par ailleurs, si tu sais qu'il en a 4, je ne vois pas pourquoi le premier code ne serait pas "optimisé", surtout compte tenu de ce que tes caractères séparateurs, bien que bizarres (un espace suffit, non ?), sont pris en charge.
Si les valeurs n'étaient séparées que par un espace, le 2ème code fonctionnerait probablement.
Dal
fiddy
Messages postés
11069
Date d'inscription
samedi 5 mai 2007
Statut
Contributeur
Dernière intervention
23 avril 2022
1 816
1 févr. 2016 à 23:14
1 févr. 2016 à 23:14
Bonjour,
Attention à la cohérence entre tes sscanf(). Comme dit [Dal], dans le premier tu as mis "%lf, %lf..." et dans le second, tu considères : "%lf %lf ...".
for(j=0;j<=4;j++)
Attention, tu as mis j==4 comme valeur max. Mais le dernier indice est 3...
Sinon, tu as utilisé la bonne méthode.
Qu'est-ce qui te fait dire que ça ne fonctionne pas ?
Cdlt,
Attention à la cohérence entre tes sscanf(). Comme dit [Dal], dans le premier tu as mis "%lf, %lf..." et dans le second, tu considères : "%lf %lf ...".
for(j=0;j<=4;j++)
Attention, tu as mis j==4 comme valeur max. Mais le dernier indice est 3...
Sinon, tu as utilisé la bonne méthode.
Qu'est-ce qui te fait dire que ça ne fonctionne pas ?
Cdlt,
[Dal]
Messages postés
6057
Date d'inscription
mercredi 15 septembre 2004
Statut
Contributeur
Dernière intervention
17 mars 2023
1 043
2 févr. 2016 à 11:25
2 févr. 2016 à 11:25
A la réflexion, je pense que sa boucle ne va lire que la 1ère valeur 4 fois... ce n'est pas fscanf ...
1 févr. 2016 à 23:15
Pas besoin d'espaces entre les %lf pour lire les variables.
C'est facultatif.
A+
Modifié par [Dal] le 2/02/2016 à 11:24
hmm..., oui, mais comme il y a un espace suivi d'une virgule dans le masque il faut qu'il y ait une cohérence entre le masque et le contenu de la chaîne (c'est pourquoi je lui demande de confirmer quel est le contenu de la chaîne).
#include <stdio.h> int main(void) { double a, b, c, d; /* ici tout va bien car il n'y a que des * espaces séparateurs dans la chaîne */ char st1[] = "12 13 14 15"; if (sscanf(st1, "%lf%lf%lf%lf", &a, &b, &c, &d) == 4) { printf("cas 1 - pour st1 : a = %f ; b = %f ; c = %f ; d = %f\n", a, b, c, d); } else printf("Erreur cas 1\n"); /* ici aussi car bien qu'il y ait des virgules en plus des * espaces, le masque passé à sscanf correspond */ char st2[] = "12 ,13 ,14 ,15"; if (sscanf(st2, "%lf ,%lf ,%lf ,%lf", &a, &b, &c, &d) == 4) { printf("cas 2 - pour st2 (avec espaces et virgules) : a = %f ; b = %f ; c = %f ; d = %f\n", a, b, c, d); } else printf("Erreur cas 2\n"); /* si on omet les espaces dans le masque, cela ne va plus */ if (sscanf(st2, "%lf,%lf,%lf,%lf", &a, &b, &c, &d) == 4) { printf("cas 3 - pour st2 (avec virgules et sans espaces) : a = %f ; b = %f ; c = %f ; d = %f\n", a, b, c, d); } else printf("Erreur cas 3\n"); return 0; }donne :
Dal
8 févr. 2016 à 15:15