scanf(), fscanf(), sscanf(), vscanf(), vsscanf(), vfscanf() - input format conversion
#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)
The scanf(3) family of functions scans input according to a format as described below. This format may contain conversion specifiers the results from such conversions, if any, are stored through the pointer arguments. The scanf(3) function reads input from the standard input stream stdin, fscanf(3) reads input from the stream pointer stream, and sscanf(3) reads its input from the character string pointed to by str. The vfscanf(3) function is analogous to vfprintf(3) and reads input from the stream pointer stream using a variable argument list of pointers (see <stdarg.h>). The vscanf(3) function scans a variable argument list from the standard input and the vsscanf(3) function scans it from a string; these are analogous to the vprintf(3) and vsprintf(3) functions respectively. Each successive pointer argument must correspond properly with each successive conversion specifier (but see `suppression' below). All conversions are introduced by the % (percent sign) character. The format string may also contain other characters. White space (such as blanks, tabs, or newlines) in the format string match any amount of white space, including none, in the input. Everything else matches only itself. Scanning stops when an input character does not match such a format character. Scanning also stops when an input conversion cannot be made (see below).
Following the %
character introducing a conversion
there may be a number of flag characters, as follows:
%[*][fieldwidth][size][conversion]
The following conversions are available:
f
.f
.0x
or 0X,
in base 8 if it
begins with 0
, and in base 10 otherwise. Only
characters that correspond to the base are used.If the first character after the open bracket is a circumflex
(
^ the set of matching characters excludes the
ones in brackets.
To include a close bracket in the set, make it the first character after the open bracket or the circumflex; any other position will end the set.
The hyphen character -
is also special; when placed
between two other characters, it adds all intervening characters to
the set. To include a hyphen, make it the last character before the
final close bracket. For instance, [^]0-9-]
means the
set `everything except close bracket, zero through nine, and
hyphen'. The string ends with the appearance of a character not in
the (or, with a circumflex, in) set or when the field width runs
out.
%p
in
printf(3)); the next pointer must be a pointer to
void.*
flag.These functions return the number of input items assigned, which
can be fewer than provided for, or even zero, in the event of a
matching failure. Zero indicates that, while there was input
available, no conversions were assigned; typically this is due to
an invalid input character, such as an alphabetic character for a
%d
conversion. The value EOF is returned if an input
failure occurs before any conversion such as an end-of-file occurs.
If an error or end-of-file occurs after conversion has begun, the
number of conversions which were successfully completed is
returned.
getc(3)
printf(3)
strtod(3)
strtol(3)
strtoul(3)