C语言格式化输入输出-转换说明符的用法

本文主要介绍C语言中格式化输入输出语句中转换说明(conversition specification)的用法

printf sprintf fprintf的转换说明符

%[flags][width][.prec][类型修饰]type

flags含义
-左对齐
+有符号值为正数时,则在值前面加上正号;若为负,则在值前面加上负号
(space)有符号值为正数时,则在值前面显示空格;若为负,则在值前面加上负号
0对于数值格式,使用0代替空格填充不足的字符;对于整数格式,如果使用了-标志或者指定精度,则该flag不起作用
#把结果转换成另一种格式。
如果为%o,则以0开始;
如果为%x或%X,则以0x或0X开始;
对于所有浮点类型,强制保留小数点;
对于%g或%G格式,则使其包含尾随0
width含义.prec含义
(number)输出的最小长度(字符数).(number)输出的精度。
对于%e,%E和%f而言,表示小数点右边数字的位数;
对于%g,%G而言,表示有效数字最大位数;
对于%s而言,表示待打印字符的最大数量;
对于整型,表示待打印数字的最小位数;
单独使用.与.0的作用相同
*(number)的值由待打印项列表中对应的变量决定.*(number)的值由待打印项列表中对应的变量决定

类型修饰用于改变type所指的变量的显示形式,其组合关系如下表所示

类型修饰d iu o x Xf F e E g G a Acspn
(none)intunsigned intdoubleintchar*void*int*
hhsigned charunsigned char



signed char*
hshort intunsigned short int



short int*
llong intunsigned long int
wint_twchar_t*
long int*
lllong long intunsigned long long int



long long int*
jintmax_tuintmax_t



intmax_t*
zsize_tsize_t



size_t*
tptrdiff_tptrdiff_t



ptrdiff_t*
L

long double



注:

(1) intmax_t 和uintmax_t定义在stdint.h中,是128位的整数类型

(2) size_t定义在stddef.h中(stdio.h已经包含该头文件),是sizeof()的值的类型

(3) ptrdiff_t是表示两个指针差值的类型

type用于type用于
i或dinta或A十六进制浮点数
uunsigned intcchar
o无符号八进制整数CISO宽字符类型(wchar_t)
x或X无符号十六进制整数(X使用大写)schar*字符串
f或F浮点数类型(默认保留六位小数)p指针(输出十六进制地址)
e或E显示为科学计数法(保留六位小数)n不输出任何字符,但是会将到该位置前输出的字符数存入后面对应的指针(默认为int*)所指的变量中
g或G根据数值不同自动选择是否使用科学计数法表示(不含尾随0),长度更短者优先%输出字符'%'

scanf sscanf fscanf的转换说明符

%[flag]type

flag含义
*跳过对应的输入项
(例如在语句scanf("%*d %*d %d",&n);中,仅将读取到的第三个整数存入变量n中,前两个值被忽略)
(number)最大字符数。输入达到最大字符数或第一次遇到空白字符时将停止

[flag]同样包含类型修饰部分,详见格式化输出部分的“类型修饰”

type用于
d或i把输入解释为有符号十进制整数(int)
u把输入解释为无符号十进制整数(unsigned int)
o把输入解释为有符号八进制整数
x把输入解释为有符号十六进制整数
s字符串(从第一个非空白字符开始,到下一个空白字符之前的所有字符都是输入)
p把输入解释成指针(地址)
a,e,f,g或A,E,F,G把输入解释成浮点数
c把输入解释成char字符(不忽略空白字符)