C语⾔printf格式化输出修饰符详解
转换说明输出
%a,%A浮点数、⼗六进制数和p-计数法(C99)
%c⼀个字符
%d有符号⼗进制数
%e,%E浮点数,e计数法
%f浮点数,⼗进制计数法
%g,%G根据数值不同⾃动选择%f或%e,%e格式在指数⼩于-4或者⼤于等于精度时使⽤
%i有符号⼗进制整数(与%d相同)
%o⽆符号⼋进制整数
%p指针
%s字符串
%u⽆符号⼗进制数
%x,%X使⽤⼗六进制数0f的⽆符号⼗六进制整数
%%打印⼀个百分号
prinf()修饰符
修饰符意义
标志
五种标志将在后⾯的表中说明,可以使⽤零个或者多个标志
⽰例: "%-10d"
digit(s)
字段宽度的最⼩值。如果字段不能容纳要打印的数或者字符串,系统会使⽤更宽的字段
⽰例: "%4d",“%10s”
.digit(s)精度.对于%e,%E和%f转换,是将要在⼩数点的右边打印的数字的位数。
对于%g和%G转换,是有效数字的最⼤位数。
对于%s转换,是将要打印的字符的最⼤数⽬。
对于整数转换,是将要打印的数字的最⼩位数。如果必要,要使⽤前导0来达到位数。只使⽤"."表⽰其后跟随⼀个0,所以%.f和%.0f相同
⽰例: “%5.2f”表⽰打印⼀个浮点数,它的字段宽度为5个字符,⼩数点后有两个数字
h
和整数转换说明符⼀起使⽤,表⽰⼀个short int或unsigned short int类型数值
⽰例: “%hu”, "%hx", "%6.4hd"
hh和证书转换说明符⼀起使⽤,表⽰⼀个signed char或unsigned char类型数值
j
和整数转换说明符⼀起使⽤,表⽰⼀个intmax_t或uintmax_t值
⽰例: "%jd","%8jx"
l和整数转换说明符⼀起使⽤,表⽰⼀个long int或unsigned long int类型值
ll
和整数转换说明符⼀起使⽤,表⽰⼀个long long int或unsigned long long int类型值(C99)
c语言printf用法例子简单
⽰例: "%lld","%8llu"
L
和浮点数转换说明符⼀起使⽤,表⽰⼀个long double值
⽰例: "%Lf", "%10.4Le"
t
和整数转换说明符⼀起使⽤,表⽰⼀个ptrdiff_t值(与两个指针之间的差相对应的类型)(C99)
⽰例: "%td", "%1ti"
z
和整数转换说明符⼀起使⽤,表⽰⼀个size_t值(sizeof返回的类型)(C99)
⽰例: "%zd","%12zx"
printf()的标志
标志意义
-
项⽬左对齐,即,会把项⽬打印在字段的左侧开始处
⽰例: "%-20s"
+
有符号的值若为正,则显⽰带加号的符号;若为负,则显⽰带减号的符号⽰例: "%+6.2f"
(空格)有符号的值若为正,则显⽰时带前导空格(但是不显⽰符号);若为负,则带减号符号。+标志会覆盖空格标志
⽰例: "% 6.2f"
#使⽤转换说明的可选形式。若为%o格式,则以0开始;若为%x和%Xgeshi ,则以0x或0X开始。
对于所有的浮点形式,#保证了即使不跟任何数字,也打印⼀个⼩数点字符。对于%g和%G格式,它防⽌尾随0被删除
⽰例: "%#o", "%#8.0f", "%+#10.3E"
对于所有的数字格式,⽤前导零⽽不是空格填充字段宽度。如果出现-标志或者指定了精度(对于整数)则忽略该标志⽰例: "%010d", "%08.3f","%02X"