6.18.45 sscanf Function
Scans formatted text from a string.
Include
<stdio.h>
Prototype
int sscanf(const char * restrict s, const char * restrict format,
                ...);
Arguments
- s
- storage string for input
- format
- format control string
- ...
- optional arguments
Return Value
Returns the number of items successfully converted and assigned. If no items are
            assigned, a 0 is returned. EOF is returned if an input error is
            encountered before the first conversion.
Remarks
This function can read from any string.
To reduce code size, the functionality of this routine can be automatically customized by the compiler with each build. See the Smart IO Routines section in your compiler's user's guide for more information on the options that control this feature.
The format string can be composed of white space characters, which
                reads input up to the first non-white-space character in the input; or ordinary
                multibyte characters, which if not read in that order, will trigger an error and
                leave the remaining characters in the input, unread. The format string can also
                contain conversion specifications, which begin with the % character
                and that specify the expected input sequences and how they are to be converted for
                assignment to objects pointed to by the pointer arguments.
Each conversion specification begins with a percent character followed by optional fields and a required type as shown here:
%[*][width][length]specifier
The presence of * immediately after the percent character indicates
                that the read and converted value should not be assigned to any object.
The width is a decimal integer that must be
                non-zero and indicates the maximum field width (in characters) of the input that is
                read to match the specification.
The length modifier specifies the size of the
                object in which the value will be assigned, as described in the following table.
                Their use with other conversion specifiers results in undefined behavior.
| Modifier | Meaning | 
|---|---|
| h | When used with d,i,o,u,x,X, ornindicates that this conversion specifier assigns to ashort
                                    intorunsigned short intobject
                                referenced by the pointer argument. | 
| hh | When used with d,i,o,u,x,X, ornindicates that this conversion specifier assigns to asigned
                                    charorunsigned charobject
                                referenced by the pointer argument. | 
| l | When used with d,i,o,u,x,X, ornindicates that this conversion specifier assigns to along
                                    intorunsigned long intobject
                                referenced by the pointer argument. | 
| l | When used the a,A,e,E,f,F,g, orGindicates that this conversion specifier
                                assigns to adoubleobject referenced by the
                                pointer argument. | 
| l | When used the c,s, or[indicates that this
                                conversion specifier assigns to awchar_tobject
                                referenced by the pointer argument. | 
| ll | When used with d,i,o,u,x,X, ornindicates that this conversion specifier assigns to along
                                    long intorunsigned long long intobject referenced by the pointer argument. | 
| L | When used the a,A,e,E,f,F,g,Gconversion specifier, indicates the argument
                                value is along double. | 
| j | When used with d,i,o,u,x,X, ornindicates that this conversion specifier assigns to aintmax_toruintmax_tobject
                                referenced by the pointer argument. | 
| t | When used with d,i,o,u,x,X, ornindicates that this conversion specifier assigns to aptrdiff_tobject referenced by the pointer
                                argument. | 
| z | When used with d,i,o,u,x,X, ornindicates that this conversion specifier assigns to asize_tobject referenced by the pointer
                                argument. | 
The conversion specifiers specify the type of
                conversion to be applied to the read sequence.
| Specifier | Receiving object type | Matches | 
|---|---|---|
| a | double | Matches an optionally signed floating-point
                                number, infinity, or NaN, whose format is the same as expected by
                                the strtodfunction for the first argument. | 
| c | chararray, orwchar_tarray | Matches a single character or the number of
                                characters specified by the field width if present. If an llength modifier is present, the input shall
                                be a sequence of multibyte characters, converted to a wide character
                                as if by a call to thembrtowcfunction. No null
                                character or wide character is added. | 
| d | signed int | Matches an optionally signed decimal
                                integer, whose format is the same as expected by the strtodfunction for the first argument when
                                using a value of 10 for the base argument. | 
| e | double | Matches an optionally signed floating-point
                                number, infinity, or NaN, whose format is the same as expected by
                                the strtodfunction for the first argument. | 
| f | double | Matches an optionally signed floating-point
                                number, infinity, or NaN, whose format is the same as expected by
                                the strtodfunction for the first argument. | 
| g | double | Matches an optionally signed floating-point
                                number, infinity, or NaN, whose format is the same as expected by
                                the strtodfunction for the first argument. | 
| i | signed int | Matches an optionally signed decimal
                                integer, whose format is the same as expected by the strtodfunction for the first argument when
                                using a value of 0 for the base argument. | 
| n | int | No input is consumed but the number of characters this call has so far read from the input stream is written to the argument with no increment of the assignment count returned by the function. If the conversion specification includes an assignment-suppressing character or a field width, the behavior is undefined. | 
| o | unsigned int | Matches an optionally signed decimal
                                integer, whose format is the same as expected by the strtoulfunction for the first argument when
                                using a value of 8 for the base argument. | 
| p | void * * | Matches an implementation-defined set of sequences, which should be the same as the set of sequences that may be produced by the %p conversion of the fprintf function. The input item is converted to a pointer value in an implementation-defined manner. If the input item is a value converted earlier during the same program execution, the pointer that results shall compare equal to that value; otherwise the behavior of the %p conversion is undefined. | 
| s | char array, orwchar_tarray | Matches a sequences of non-white-space characters, which is
                                    written to the array argument and appended with a null
                                    terminating character. If an  | 
| x | unsigned int | Matches an optionally signed decimal
                                integer, whose format is the same as expected by the strtoulfunction for the first argument when
                                using a value of 16 for the base argument. | 
| % | Matches a single %character. No assignment takes place. | |
| [ | char array, orwchar_tarray | Matches all the characters in the input
                                that have been specified between the [and trailing]character, unless the character after the
                                opening bracket is a circumflex,^, in which case a
                                match is only made with characters that do not appear in the
                                brackets. If the conversion specifier begins with[]or[^], the right bracket
                                character will match the input and the next following right bracket
                                character is the matching right bracket that ends the specification.
                                A null character will be appended to the characters read. If anllength modifier is present, the input shall
                                be a sequence of multibyte characters and a null wide character will
                                be appended to the matched wide characters. | 
Example
See the notes at the beginning of this chapter or section for
                        information on using printf() or scanf()
                        (and other functions reading and writing the stdin or
                                stdout streams) in the example code.
#include <stdio.h>
int main(void)
{
  char s[] = "5 T green 3000000.00";
  int number, items;
  char letter;
  char color[10];
  float salary;
  items = sscanf(s, "%d %c %s %f", &number, &letter,
               &color, &salary);
  printf("Number of items scanned = %d\n", items);
  printf("Favorite number = %d\n", number);
  printf("Favorite letter = %c\n", letter);
  printf("Favorite color = %s\n", color);
  printf("Desired salary = $%.2f\n", salary);
}Example Output
Number of items scanned = 4
Favorite number = 5
Favorite letter = T
Favorite color = green
Desired salary = $3000000.00