Provided by: manpages-fr-dev_3.65d1p1-1_all bug

NOM

       scanf, fscanf, sscanf, vscanf, vsscanf, vfscanf - Entrées formatées

SYNOPSIS

       #include <stdio.h>

       int scanf(const char *format, ...);
       int fscanf(FILE *stream, const char *format, ...);
       int sscanf(const char *str, const char *format, ...);

       #include <stdarg.h>

       int vscanf(const char *format, va_list ap);
       int vsscanf(const char *str, const char *format, va_list ap);
       int vfscanf(FILE *stream, const char *format, va_list ap);

   Exigences    de    macros    de   test   de   fonctionnalités   pour   la   glibc   (consultez
   feature_test_macros(7)) :

       vscanf(), vsscanf(), vfscanf() :
           _XOPEN_SOURCE >= 600 || _ISOC99_SOURCE || _POSIX_C_SOURCE >= 200112L
           ou cc -std=c99

DESCRIPTION

       Les fonctions de la famille scanf() analysent leurs entrées conformément au format  décrit
       plus  bas.  Ce  format  peut  contenir  des  indicateurs  de conversion. Les résultats des
       conversions, s'il y en a, sont  stockés  dans  des  endroits  pointés  par  des  arguments
       pointeurs qui suivent le format. Chaque argument pointeur doit être du type approprié pour
       la valeur retournée par la spécification de conversion correspondante.

       Si le nombre de spécifications de conversion dans  format  excède  le  nombre  d'arguments
       pointeur,  le résultat est indéterminé. Si le nombre d'arguments pointeur excède le nombre
       de spécifications de conversion,  les  arguments  pointeur  en  excès  sont  évalués  mais
       ignorés.

       La  fonction  scanf() lit ses données depuis le flux d'entrée standard stdin, fscanf() lit
       ses entrées depuis le flux pointé par stream, et sscanf() lit ses entrées dans  la  chaîne
       de caractères pointée par str.

       La  fonction  vfscanf()  est  analogue  à  vfprintf(3) et lit ses arguments depuis le flux
       pointé par stream  en  utilisant  une  liste  variable  d'arguments  pointeurs,  consultez
       stdarg(3).  La fonction vscanf() examine l'entrée standard en utilisant une liste variable
       d'arguments  pointeurs  et  la  fonction  vsscanf()  examine  une   chaîne.   Elles   sont
       respectivement analogues aux fonctions vprintf(3) et vsprintf(3).

       La  chaîne  format  consiste  en  une  séquence  de directives qui décrit comme traiter la
       séquence des caractères d'entrée. Si le traitement des  directives  échoue,  aucune  autre
       entrée  n'est  lue  et  scanf()  revient.  Un  « échec »  peut être soit un échec d'entrée
       signifiant que les  caractères  d'entrée  ne  sont  pas  disponibles,  soit  un  échec  de
       correspondance signifiant que l'entrée n'est pas appropriée (voir plus loin)

       Une directive peut être :

       •      Une  séquence  de  caractères  blancs  (espace,  tabulation, nouvelle ligne, etc. ;
              consultez isspace(3)).  Cette  directive  correspond  à  un  nombre  quelconque  de
              caractères blancs, y compris aucun, dans l'entrée.

       •      Un  caractère  ordinaire  (c'est-à-dire  autre  qu'un  caractère  blanc  et  que le
              caractère « % ». Ce caractère doit exactement correspondre au caractère suivant  de
              l'entrée.

       •      Une spécification de conversion qui débute avec le caractère « % ». Une séquence de
              caractères de l'entrée est convertie conformément à la spécification et le résultat
              est  placé dans l'argument pointeur correspondant. Si l'élément suivant de l'entrée
              ne correspond pas à la spécification de conversion, la conversion échoue — c'est un
              échec de correspondance.

       Chaque spécification de conversion dans format commence avec soit le caractère « % », soit
       la séquence de caractères « %n$ » (voir plus loin pour la distinction) suivie par :

       •      Un caractère d'affectation-suppression optionnel « * » : scanf() lit l'entrée comme
              indiqué  par  la  spécification de conversion mais ne tient pas compte de l'entrée.
              Aucun  argument  pointeur  n'est  nécessaire  et  cette  spécification  n'est   pas
              comptabilisée dans le nombre d'affectations réussies renvoyé par scanf().

       •      Un  caractère  « m » optionnel. Il est utilisé dans les conversions de chaînes (%s,
              %c, %[) et soulage l'appelant du besoin  d'allouer  un  tampon  correspondant  pour
              conserver  l'entrée :  à la place, scanf() alloue un tampon de taille suffisante et
              affecte l'adresse de ce tampon à l'argument pointeur correspondant qui doit être un
              pointeur  vers une variable char * (il n'est pas nécessaire que cette variable soit
              initialisée avant l'appel). L'appelant doit  par  la  suite  libérer  (free(3))  ce
              tampon lorsqu'il devient inutile.

       •      Un  entier décimal optionnel qui indique la taille maximum du champ. La lecture des
              caractères s'arrête soit lorsque ce maximum est atteint, soit lorsque on trouve  un
              caractère  qui  ne  correspond  pas,  celui  qui  arrive le premier. La plupart des
              conversions abandonnent les caractères blancs de tête (les exceptions  sont  notées
              plus  loin),  et  ces  caractère  abandonnés n'entrent pas en compte dans la taille
              maximale du champ. Les conversions d'entrée de chaînes stocke un octet nul (« \0 »)
              final  pour  marquer la fin de l'entrée ; la largeur maximale du champ n'inclut pas
              ce caractère de terminaison.

       •      Un caractère modificateur de type optionnel. Par exemple, le modificateur de type l
              est  utilisé  avec  les  conversions  d'entrée  telles  que  %d  pour spécifier que
              l'argument pointeur correspondant fait référence à  un  long  int  plutôt  qu'à  un
              pointeur sur un int.

       •      Un  spécificateur  de  conversion  qui  spécifie  le  type de conversion d'entrée à
              effectuer.

       Les spécifications de conversion dans format sont de deux formes : soit  elles  commencent
       par  « % »,  soit  elles  commencent  par  « %n$ ».  Les  deux  formes ne doivent pas être
       mélangées dans la même chaîne format, excepté qu'une chaîne contenant  les  spécifications
       « %n$ »  peut  inclure  %%  et  %*. Si format contient des spécifications « % », celles-ci
       correspondent, dans l'ordre, aux arguments pointeur successifs. Dans la forme « %n$ » (qui
       est spécifiée par POSIX.1-2001 mais pas par C99), n est un entier décimal qui spécifie que
       l'entrée convertie devrait être placée  à  l'endroit  référencé  par  le  n-ième  argument
       pointeur suivant format.

   Conversions
       Les  caractères modificateurs de type suivant peuvent se apparaître dans une spécification
       de conversion :

       h      Indique que la conversion sera de type d, i, o, u, x, X ou n  et  que  le  pointeur
              suivant  est  un pointeur sur un short int ou un unsigned short int (plutôt que sur
              un int).

       hh     Comme pour h, sauf que le pointeur suivant est un pointeur sur un signed char ou un
              unsigned char.

       j      Comme  pour  h,  sauf que le pointeur suivant est un pointeur sur un intmax_t ou un
              uintmax_t. Ce modificateur a été introduit dans C99.

       l      Indique que la conversion sera de type d, i, o, u, x, X ou n  et  que  le  pointeur
              suivant  est un pointeur sur un long int ou un unsigned long int (plutôt que sur un
              int), ou que la conversion sera de type e, f ou g et que le pointeur suivant est un
              pointeur  sur  un  double  (plutôt  que  sur  un float). Indiquer deux caractères l
              successifs est équivalent à indiquer  L.  Si  c'est  utilisé  avec  %c  ou  %s,  le
              paramètre  correspondant  est  considéré, respectivement, comme un pointeur vers un
              caractère large ou une chaîne de caractères larges.

       L      Indique que la conversion sera de type e, f ou g et que le pointeur suivant est  un
              pointeur  sur  un long double ou que la conversion sera de type d, i, o, u, ou x et
              que le pointeur suivant est un pointeur sur un long long.

       q      est équivalent à L. Ce spécificateur n'existe pas en C ANSI.

       t      Comme pour h, mais le pointeur suivant  est  un  pointeur  vers  un  ptrdiff_t.  Ce
              modificateur a été introduit dans C99.

       z      Comme  pour  h,  mais  le  pointeur  suivant  est  un  pointeur  vers un size_t. Ce
              modificateur a été introduit dans C99.

       Les spécificateurs de conversion suivant sont disponibles :

       %      Correspond à un caractère « % ». Ceci  signifie  qu'un  spécificateur  %%  dans  la
              chaîne  de  format  correspond  à  un seul caractère « % » dans la chaîne d'entrée.
              Aucune conversion (mais les caractères blancs de début  sont  ignorés),  et  aucune
              assignation n'a lieu.

       d      Correspond à un entier décimal éventuellement signé, le pointeur correspondant doit
              être un pointeur vers un int.

       D      Équivalent  à  ld,  utilisé  uniquement  pour  compatibilité  avec   des   versions
              précédentes  (et  seulement  dans  libc4.  Dans  libc5  et  glibc, le %D est ignoré
              silencieusement, ce qui conduit d'anciens programmes à échouer mystérieusement).

       i      Correspond à un entier éventuellement signé. Le pointeur suivant doit être du  type
              int.  L'entier  est  en base 16 (hexadécimal) s'il commence par 0x ou 0X, en base 8
              (octal) s'il commence par  un  0,  et  en  base  10  sinon.  Seuls  les  caractères
              correspondants à la base concernée sont utilisés.

       o      Correspond  à  un  entier  octal  non signé. Le pointeur correspondant doit être un
              pointeur vers un unsigned int.

       u      Correspond à un entier décimal non signé. Le pointeur suivant doit être un pointeur
              vers un unsigned int.

       x      Correspond  à  un  entier  hexadécimal  non signé. Le pointeur suivant doit être un
              pointeur vers un unsigned int.

       X      Équivalent à x

       f      Correspond à un nombre réel éventuellement signé. Le  pointeur  correspondant  doit
              être un pointeur vers un float.

       e      Équivalent à f.

       g      Équivalent à f.

       E      Équivalent à f.

       a      (C99) Équivalent à f.

       s      Correspond  à  une  séquence  de  caractères  différents  des caractères blancs. Le
              pointeur correspondant doit être un pointeur sur un tableau de caractères qui  doit
              être  assez large pour accueillir toute la séquence d'entrée, ainsi que l'octet nul
              final (« \0 ») qui est ajouté automatiquement. La conversion  s'arrête  au  premier
              caractère blanc, ou à la longueur maximale du champ.

       c      Correspond  à  une  séquence  de  caractères  dont la longueur est spécifiée par la
              largeur maximum de champ (par défaut 1). Le pointeur suivant doit être un  pointeur
              vers un char, et il doit y avoir suffisamment de place dans la chaîne pour tous les
              caractères. Aucun octet nul final n'est ajouté. Les caractères blancs de  début  ne
              sont  pas  supprimés.  Si on veut les éliminer, il faut utiliser une espace dans le
              format.

       [      Correspond à une séquence non vide de caractères appartenant à un  ensemble  donné.
              Le  pointeur  correspondant  doit  être un pointeur vers un char et il doit y avoir
              suffisamment de place dans le tableau de caractères pour accueillir la chaîne ainsi
              qu'un  octet  nul  final.  Les caractères blancs du début ne sont pas supprimés. La
              chaîne est  constituées  de  caractères  inclus  ou  exclus  d'un  ensemble  donné.
              L'ensemble  est  composé  des  caractères  compris  entre les deux crochets [ et ].
              L'ensemble exclut ces caractères si le premier après  le  crochet  ouvrant  est  un
              accent  circonflexe (^). Pour inclure un crochet fermant dans l'ensemble, il suffit
              de  le  placer  en  première  position  après  le  crochet  ouvrant,  ou   l'accent
              circonflexe ;  à  tout  autre  emplacement  il  servira  à  terminer l'ensemble. Le
              caractère tiret - a également une signification particulière. Quand  il  est  placé
              entre deux autres caractères, il ajoute à l'ensemble les caractères intermédiaires.
              Pour inclure un tiret dans l'ensemble, il faut le placer en dernière position avant
              le  crochet  fermant.  Par exemple, [^]0-9-] correspond à l'ensemble « Tout sauf le
              crochet fermant, les chiffres de 0 à 9, et le tiret ». La  chaîne  se  termine  dès
              l'occurrence  d'un  caractère  exclu (ou inclus s'il y à un accent circonflexe ) de
              l'ensemble, ou dès qu'on atteint la longueur maximale du champ.

       p      Correspond à une valeur de pointeur (comme  affichée  par  %p  dans  printf(3).  Le
              pointeur suivant doit être un pointeur sur un pointeur sur void.

       n      Aucune  lecture  n'est  faite.  Le nombre de caractères déjà lus est stocké dans le
              pointeur correspondant, qui doit être un pointeur vers un int.  Ce  n'est  pas  une
              conversion,  mais  le  stockage  peut  quand  même  être supprimé avec le caractère
              d'affectation-suppression *. Le standard C indique : « L'exécution d'une  directive
              %n  n'incrémente  pas le compteur d'assignations renvoyé à la fin de l'exécution ».
              Mais il semble qu'il y ait des contradictions sur ce  point.  Il  est  probablement
              sage  de ne pas faire de suppositions sur l'effet de la conversion %n sur la valeur
              renvoyée.

VALEUR RENVOYÉE

       Ces fonctions renvoient le nombre d'éléments d'entrées correctement mis en  correspondance
       et  assignés.  Ce  nombre  peut être plus petit que le nombre d'éléments attendus, et même
       être nul, s'il y a une erreur de mise en correspondance.

       La valeur EOF est renvoyée si la fin de l'entrée est atteinte avant la première conversion
       réussie ou si un échec de correspondance survient. EOF est également renvoyé si une erreur
       de lecture survient, auquel cas l'indicateur d'erreur pour le flux  (consultez  ferror(3))
       est positionné et errno est remplie en conséquence

ERREURS

       EAGAIN Le  descripteur  de  fichier  stream sous-jacent est non bloquant et l'opération de
              lecture bloquerait.

       EBADF  Le descripteur de fichier stream sous-jacent n'est pas valide  ou  bien  n'est  pas
              ouvert en lecture.

       EILSEQ La séquence d'octet en entrée ne constitue pas un caractère valable.

       EINTR  La lecture a été interrompue par un signal ; consultez signal(7).

       EINVAL Pas suffisamment de paramètres ; ou bien format est NULL.

       ENOMEM Plus de mémoire disponible.

       ERANGE Le  résultat  de  la  conversion  entière est plus grand que la taille pouvant être
              stockée dans le type entier correspondant.

CONFORMITÉ

       Les fonctions fscanf(), scanf(), et sscanf() sont conformes à C89,  C99  et  POSIX.1-2001.
       Ces normes ne spécifient pas l'erreur ERANGE.

       Le  spécificateur q est une notation BSD 4.4 pour long long, alors que ll ou l'utilisation
       de L dans les conversions entières sont des notations GNU.

       Les versions Linux de ces fonctions sont basées sur la bibliothèque libio  GNU.  Jetez  un
       œil sur la documentation info de la libc GNU (glibc-1.08) pour une description complète.

NOTES

   Le modificateur d'affectation-allocation « a »
       Initialement,  la  bibliothèque  C  de  GNU  prenait  en charge l'allocation dynamique des
       chaînes de caractères en entrée (comme une extension non standard) au moyen du caractère a
       (cette  fonctionnalité  remonte  au  moins  à  la  version  2.0 de glibc). Ainsi, il était
       possible, grâce au code suivant, de faire que scanf() alloue un tampon pour une chaîne  en
       entrée, et renvoie un pointeur vers ce tampon dans *buf:

           char *buf;
           scanf("%as", &buf);

       L'utilisation  de  la lettre a dans ce but posait problème étant donné que a est également
       synonyme de f dans le standard ISO C (entrée de nombre à virgule flottante).  POSIX.1-2008
       spécifie  en  revanche  que  le  modificateur  m  doit  être  utilisée  pour l'affectation
       allocation (comme indiqué dans la DESCRIPTION plus haut).

       Notez que le modificateur a n'est pas disponible si le programme a été  compilé  avec  gcc
       -std=c99  ou  gcc  -D_ISOC99_SOURCE (à moins que _GNU_SOURCE n'ait également été indiqué),
       auquel cas a est interprété comme un spécificateur de nombres en virgule  flottante  (voir
       plus haut).

       Le  modificateur  m  est  pris  en  charge  depuis la version 2.7 de glibc et les nouveaux
       programmes doivent utiliser ce modificateur plutôt que a.

       En plus d'être un standard de POSIX, le modificateur m présente les avantages suivants par
       rapport au modificateur a:

       * Il peut être appliqué aux spécificateurs de conversion %c (par exemple %3mc).

       * Il  lève toute ambiguité avec le spécificateur de conversion en virgule flottante %a (et
         n'est pas affecté par gcc -std=c99 etc.).

BOGUES

       Toutes ces fonctions sont totalement conformes à C89, mais lui ajoutent les spécificateurs
       q  et a ainsi que des comportements supplémentaires des spécificateurs L et l. Ce derniers
       doivent  être  considérés  comme  des  bogues,  car  ils  modifient  le  comportement   de
       spécificateurs définis dans C89.

       Certaines combinaisons de modificateurs de type et de spécificateurs de conversion définis
       par le C ANSI n'ont pas de sens (par exemple %Ld). Bien  qu'elles  aient  un  comportement
       bien  défini sous Linux, ce n'est peut être pas le cas sur d'autres architectures. Il vaut
       donc mieux n'utiliser que des modificateurs définis en C ANSI, c'est-à-dire, utilisez q  à
       la place de L avec les conversions d, i, o, u, x et X ou ll.

       L'utilisation  q  n'est  pas  la  même  sous  BSD 4.4,  car  il peut être utilisé avec des
       conversions de réels de manière équivalente à L. [NDT] La conversion %s  devrait  toujours
       être  accompagnée  d'une longueur maximale de chaîne de caractères. En effet, il existe un
       risque de débordement de tampon, qui peut conduire à un trou de sécurité important dans un
       programme setuid ou setgid.

EXEMPLE

       Pour  utiliser  l'indicateur  de  conversion  d'allocation  dynamique,  indiquez  m  comme
       modificateur de longueur (par  conséquent  %ms  ou  %m[range]).  L'appelant  doit  libérer
       (free(3)) l'espace occupé par la chaîne renvoyée, comme dans l'exemple suivant :

           char *p;
           int n;

           errno = 0;
           n = scanf("%m[a-z]", &p);
           if (n == 1) {
               printf("read: %s\n", p);
               free(p);
           } else if (errno != 0) {
               perror("scanf");
           } else {
               fprintf(stderr, "Pas de caractères correspondants\n");
           }

       Comme  montré  dans  cet  exemple,  il n'est nécessaire d'appeler free(3) que si l'appel à
       scanf() a réussi à lire une chaîne.

VOIR AUSSI

       getc(3), printf(3), setlocale(3), strtod(3), strtol(3), strtoul(3)

COLOPHON

       Cette page fait partie de la publication 3.65 du projet man-pages Linux.  Une  description
       du  projet  et  des  instructions  pour  signaler  des  anomalies  peuvent être trouvées à
       l'adresse http://www.kernel.org/doc/man-pages/.

TRADUCTION

       Depuis   2010,   cette   traduction   est   maintenue   à   l'aide   de    l'outil    po4a
       <http://po4a.alioth.debian.org/>  par l'équipe de traduction francophone au sein du projet
       perkamon <http://perkamon.alioth.debian.org/>.

       Christophe   Blaess   <http://www.blaess.fr/christophe/>   (1996-2003),    Alain    Portal
       <http://manpagesfr.free.fr/>  (2003-2006).  Nicolas  François  et  l'équipe francophone de
       traduction de Debian (2006-2009).

       Veuillez     signaler     toute     erreur     de     traduction     en     écrivant     à
       <debian-l10n-french@lists.debian.org>   ou   par   un  rapport  de  bogue  sur  le  paquet
       manpages-fr.

       Vous pouvez toujours avoir accès à la version anglaise de  ce  document  en  utilisant  la
       commande « man -L C <section> <page_de_man> ».