NAME 
scanf, fscanf, sscanf - formatted input conversion
SYNOPSIS 
#include <stdio.h>
int scanf(format [ , pointer ] .
. . ) 
const char *format;
int fscanf(stream, format [ ,
pointer ] . . . ) 
FILE *stream; 
const char *format;
int sscanf(s, format [ , pointer
] . . . ) 
const char *s, *format;
#include <varargs.h> 
int vscanf(format, args) 
const char *format; 
va_list args;
int vfscanf(stream, format,
args) 
FILE *stream; 
const char *format; 
va_list args;
int vsscanf(s, format, args)
const char *s, *format; 
va_list args;
DESCRIPTION 
Scanf reads from the standard input stream stdin. Fscanf
reads 
from the named input stream. Sscanf reads from the character
string s. Each function reads characters, interprets them
according to a format, and stores the results in its
arguments. 
Each expects as arguments a control string format, described
below, 
and a set of pointer arguments indicating where the
converted input 
should be stored. Alternate forms, in which the arguments
have 
already been captured using the variable-length argument
facilities 
of varargs(3), are available under the names vscanf,
vfscanf, and 
vsscanf.
The control string usually
contains conversion specifications, 
which are used to direct interpretation of input sequences.
The 
control string may contain:
1. Blanks, tabs or newlines,
which match optional white space in 
the input.
2. An ordinary character (not %)
which must match the next 
character of the input stream.
3. Conversion specifications,
consisting of the character %, an 
optional assignment suppressing character *, an optional
numerical maximum field width, and a conversion
character.
A conversion specification
directs the conversion of the next input 
field; the result is placed in the variable pointed to by
the 
corresponding argument, unless assignment suppression was
indicated 
by *. An input field is defined as a string of non-space
characters; it extends to the next inappropriate character
or until 
the field width, if specified, is exhausted.
The conversion character
indicates the interpretation of the input 
field; the corresponding pointer argument must usually be of
a 
restricted type. The following conversion characters are
legal:
% a single ‘%’ is
expected in the input at this point; no 
assignment is done.
d a decimal integer is expected;
the corresponding argument 
should be an integer pointer.
o an octal integer is expected;
the corresponding argument should 
be a integer pointer.
x a hexadecimal integer is
expected; the corresponding argument 
should be an integer pointer.
s a character string is
expected; the corresponding argument 
should be a character pointer pointing to an array of 
characters large enough to accept the string and a
terminating 
‘ ’, which will be added. The input field is
terminated by a 
space character or a newline.
c a character is expected; the
corresponding argument should be a 
character pointer. The normal skip over space characters is
suppressed in this case; to read the next non-space
character, 
try ‘%1s’. If a field width is given, the
corresponding 
argument should refer to a character array, and the
indicated 
number of characters is read.
e,f a floating point number is
expected; the next field is 
converted accordingly and stored through the corresponding
argument, which should be a pointer to a float. 
The input format for floating point numbers is an optionally
signed string of digits possibly containing a decimal point,
followed by an optional exponent field consisting of an E or
e 
followed by an optionally signed integer.
[ indicates a string not to be
delimited by space characters. 
The left bracket is followed by a set of characters and a
right 
bracket; the characters between the brackets define a set of
characters making up the string. If the first character is
not 
circumflex (^), the input field is all characters until the
first character not in the set between the brackets; if the
first character after the left bracket is ^, the input field
is 
all characters until the first character which is in the
remaining set of characters between the brackets. The 
corresponding argument must point to a character array.
The conversion characters d, o
and x may be capitalized or preceded 
by l to indicate that a pointer to long rather than to int
is in 
the argument list. Similarly, the conversion characters e or
f may 
be capitalized or preceded by l to indicate a pointer to
double 
rather than to float. The conversion characters d, o and x
may be 
preceded by h to indicate a pointer to short rather than to
int.
The scanf functions return the
number of successfully matched and 
assigned input items. This can be used to decide how many
input 
items were found. The constant EOF is returned upon end of
input; 
note that this is different from 0, which means that no
conversion 
was done; if conversion was intended, it was frustrated by
an 
inappropriate character in the input.
For example, the call
int i; float x; char name[50];
scanf("%d%f%s", &i, &x, name);
with the input line
25 54.32E-1 thompson
will assign to i the value 25, x
the value 5.432, and name will 
contain ‘thompson ’. Or,
int i; float x; char name[50];
scanf("%2d%f%*d%[1234567890]", &i, &x,
name);
with input
56789 0123 56a72
will assign 56 to i, 789.0 to x,
skip ‘0123’, and place the string 
‘56 ’ in name. The next call to getchar will
return ‘a’.
SEE ALSO 
atof(3), getc(3), printf(3)
DIAGNOSTICS 
The scanf functions return EOF on end of input, and a short
count 
for missing or illegal data items.
BUGS 
The success of literal matches and suppressed assignments is
not 
directly determinable.