Index of Section 3 Manual Pages
| Interix / SUA | sscanf.3 | Interix / SUA |
sscanf(3) sscanf(3)
scanf()
NAME
scanf(), fscanf(), sscanf(), vscanf(), vsscanf(), vfscanf() - input format
conversion
SYNOPSIS
#include
int scanf (const char *format ...)
int fscanf (FILE *stream, const char *format ...)
int sscanf (const char *str, const char *format ...)
#include
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)
DESCRIPTION
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
). 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).
CONVERSIONS
Following the % character introducing a conversion there may be a number
of flag characters, as follows:
%[*][fieldwidth][size][conversion]
*
Suppresses assignment. The conversion that follows occurs as usual,
but no pointer is used; the result of the conversion is simply
discarded.
fieldwidth
There may be an optional maximum field width, expressed as a decimal
integer. If no width is given, a default of `infinity' is used (with
one exception, below); otherwise at most this many characters are
scanned in processing the conversion. Before conversion begins, most
conversions skip white space; this white space is not counted against
the field width.
size
The characters h, l, and L indicate the size of the receiving object:
h
Indicates that the corresponding pointer is a short data type: hd,
hi, and hn indicate a short int; ho, hu, and hx indicate an
unsigned short int.
l
(The letter ell.) Indicates that the corresponding pointer is a
long or double data type: ld, li, and ln indicate a long int; lo,
lu, and lx indicate an unsigned long int; le, lf, and lg indicate
a double.
L
Indicates that the corresponding pointer is a long double type:
Le, Lf, and Lg indicate a long double.
The following conversions are available:
%
Matches a literal `%'. That is, `%%' in the format string matches a
single input `%' character. No conversion is done, and assignment does
not occur.
c
Matches a sequence of width count characters (default 1); the next
pointer must be a pointer to char, and there must be enough room for
all the characters (no terminating NUL is added). The usual skip of
leading white space is suppressed. To skip white space first, use an
explicit space in the format.
C
Matches a sequence of width count wide-character codes (default 1);
the next pointer must be a pointer to wchar_t, and there must be
enough room for all the characters (no terminating NUL is added). The
usual skip of leading white space is suppressed. To skip white space
first, use an explicit space in the format. This conversion can also
be expressed as lc.
d
Matches an optionally signed decimal integer; the next pointer must be
a pointer to int.
E, e
Equivalent to f.
F, f
Matches an optionally signed floating-point number; the next pointer
must be a pointer to float.
g
Equivalent to f.
i
Matches an optionally signed integer; the next pointer must be a
pointer to int. The integer is read in base 16 if it begins with 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.
n
Nothing is expected; instead, the number of characters consumed thus
far from the input is stored through the next pointer, which must be a
pointer to int. This is not a conversion, although it can be
suppressed with the * flag.
o
Matches an octal integer; the next pointer must be a pointer to int.
p
Matches a pointer value (as printed by %p in printf(3)); the next
pointer must be a pointer to void.
s
Matches a sequence of non-white-space characters; the next pointer
must be a pointer to char, and the array must be large enough to
accept all the sequence and the terminating NUL character. The input
string stops at white space or at the maximum field width, whichever
occurs first.
S
Matches a sequence of non-white-space wide-character codes; the next
pointer must be a pointer to wchar_t, and the array must be large
enough to accept all the sequence and the terminating NUL character.
The input string stops at white space or at the maximum field width,
whichever occurs first. This conversion can also be be expressed as
ls.
u
Matches an optionally signed decimal integer; the next pointer must be
a pointer to unsigned int.
x
Matches an optionally signed hexadecimal integer; the next pointer
must be a pointer to unsigned int.
[
Matches a nonempty sequence of characters from the specified set of
accepted characters; the next pointer must be a pointer to char, and
there must be enough room for all the characters in the string, plus a
terminating NUL character. To match a string that is not delimited by
white space, use this to specify a set of characters within square
brackets ([]). This is used when the s conversion specifier is not
appropriate. The usual skip of leading white space is suppressed.
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.
RETURN VALUES
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.
SEE ALSO
getc(3)
printf(3)
strtod(3)
strtol(3)
strtoul(3)
USAGE NOTES
The following functions are thread safe: scanf, fscanf, sscanf, vscanf,
vsscanf. The vfscanf function is not thread safe.
None of these functions are async-signal safe.