格式说明符

格式转换说明符printf() / scanf()

 

                  表一 printf()的转换说明符

转换说明
输 出

%a
浮点数、十六进制数字和p-记数法 (C99)

%A
浮点数、十六进制数字和P-记数法 (C99)

%c
一个字符

%d
有符号十进制整数

%e
浮点数、e-记数法

%E
浮点数、E-记数法

%f
浮点数,十进制记数法

%g
根据数值不同自动选择%f或者%e。%e格式在指数小于-4或者大于等于精度时使用

%G
根据数值不同自动选择%f或者%E。%E格式在指数小于-4或者大于等于精度时使用

%i
有符号十进制整数 (与%d相同)

%o
无符号八进制整数

%p
指针(就是指地址)

%s
字符串

%u
无符号十进制整数

%x
使用十六进制数字0f 的无符号十六进制整数

%X
使用十六进制数字0F的无符号十六进制整数

%%
打印一个百分号

 

                  表二 printf() 修饰符

修饰符
意 义

标志
五种标志 (-、+、空格、# 和0) 都将在表三中描述,可以使用零个或多个标志

digit(s)
字段宽度的最小值。如果该字段不能容纳要打印的数或者字符串,系统会使用更宽的字段。示例:“%4d”

.digit(s)
精度。对于%e、%E和%f转换,是将要在小数点的右边打印的数字的位数。对于%g和%G转换,是有效数字的最大位数。对于%s转换,是将要打印的字符的最大数目。对于整数转换,是将要打印的数字的最小位数;如果必要,要使用前导零来达到这个位数。只使用“.”表示其后跟随一个零,所以%.f与%.0f相同。示例:“%5.2f”打印一个浮点数,他的字段宽度为5个字符,小数点后有两个数字。

h
和整数转换说明符一起使用,表示一个short int 或者 unsigned short int 类型数值。

示例:“%hu”、“%hx”和“%6.4hd”

hh
和整数转换说明符一起使用,表示一个signed char 或者unsigned char类型数值。

示例:“%hhu”、“%hhx”和“%6.4hhd”

j
和整数转换说明符一起使用,表示一个intmax_t或uintmax_t值。

示例:“%jd”和“%8jX”

l
和整数说明符一起使用,表示一个long int 或者unsigned long int 类型值。

示例:“%ld”和“%8lu”

ll
和整数说明符一起使用,表示一个long long int或 unsigned long long int 类型值 (C99)。

示例:“%lld”和“%8llu”

L
和浮点转换说明符一起使用,表示一个long double值。

示例:“%Lf”和“%10.4Le”

t
和整数转换说明符一起使用,表示一个ptrdiff_t值(与两个指针之间的差相对应的类型) (C99)

示例:“%td”和“%12ti”

z
和整数转换说明符一起使用,表示一个size_t值(sizeof返回的类型) (C99)。

示例:“%zd”和“%12zx”

                  表三 printf()的标志

修饰符
意 义

-
项目是左对齐的,也就是说,会把项目打印在字段的左侧开始处。示例:“%-20s”

+
有符号的值若为正,则显示带加号的符号;若为负,则带减号的符号。示例:“%+6.2f”

(空格)
有符号的值若为正,则显示时带前导空格(但是不显示符号);若为负,则带减号符号。+标志会覆盖空格标志。示例:“% 6.2f”

#
使用转换说明的可选形式。若为%o格式,则以0开始;若为%x和%X格式,则以0x或0X开始,对于所有的浮点形式,#保证了即使不限任何数字,也打印一个小数点字符。对于%g和%G格式,它防止尾随零被删除。示例:“%#o”、“%#8.0f”和“%+#10.3E”

0
对于所有的数字格式,用前导零而不是用空格填充字段宽度。如果出现-标志或者指定了精度(对于整数)则忽略该标志。示例:“%010d”和“%08.3f”

 

                  表四 ANSIC 中 scanf()的转换说明符

转换说明符
意 义

%c
把输入解释成一个字符

%d
把输入解释成一个有符号十进制整数

%e,%f,%g, %a
把输入解释成一个浮点数 (%a是C99标准)

%E,%F,%G,%A
把输入解释成一个浮点数 (%A是C99标准)

%i
把输入解释成一个有符号十进制整数

%o
把输入解释成一个有符号八进制数

%p
把输入解释成一个指针(地址)

%s
把输入解释成一个字符串;输入的内容以一个非空白字符作为开始,并且包含知道下一个空白字符的全部字符

%u
把输入解释成一个无符号十进制整数

%x,%X
把输入解释成一个有符号十六进制整数

 

                  表五 scanf()的转换修饰符

修饰符
意 义

*
滞后赋值。示例:“%*d”

digit(s)
最大字段宽度;在达到最大字段宽度或者遇到第一个空白字符时(不管哪一个先发生都一样)停止对输入项的读取。示例:“%10s”

hh
把整数读作signed char 或 unsigned char 。示例:“%hhd”“%hhu”

ll
把整数读作long long或者 unsigned long long (C99)。示例:“%lld”“%llu”

h,l或L
“%hd”和“hi”指示该值将会存储在一个short int中。

“%ho”“%hx”和“%hu”指示该值将会存储在一个unsigned short int中。

“%ld”和“%li”指示该值将会存储在一个long中。

“%lo”“%lx”和“%lu”指示该值将会存储在一个unsigned long中。

“%le”“%lf”和“%lg”指示该值以double类型存储。将L(而非l)与e、f和g一起使用指示该值以long double类型存储。

如果没有这些修饰符,d、i、o和x指示int类型,而e、f和g指示float类型。

 

转载于:https://www.cnblogs.com/trenail/p/4301403.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: printf输出格式说明符是用于指定输出格式的占位符,用于控制输出的格式和精度。常用的格式说明符包括: 1. %d:输出十进制整数。 2. %f:输出浮点数。 3. %c:输出字符。 4. %s:输出字符串。 5. %p:输出指针地址。 6. %o:输出八进制整数。 7. %x或%X:输出十六进制整数,%x输出小写字母,%X输出大写字母。 8. %e或%E:输出科学计数法表示的浮点数,%e输出小写字母,%E输出大写字母。 9. %u:输出无符号十进制整数。 10. %g或%G:根据数值的大小自动选择%f或%e输出浮点数,%g输出小写字母,%G输出大写字母。 除了以上常用的格式说明符外,还有一些其他的格式说明符,如%ld、%lld、%lu等,用于输出长整型、长长整型、无符号长整型等数据类型。在使用printf输出时,需要根据实际需要选择合适的格式说明符,以达到正确的输出效果。 ### 回答2: printf 是 C 程序中非常常用的输出函数,可以将变量和常量以指定的格式输出到控制台上或者文件中。printf 的输出格式说明符是非常重要的组成部分,可以掌握他们的含义与用法将会有助于更好的使用 printf 函数。 下面我们来详细解读一下格式说明符中常用的几个: %s:将字符串输出。例如:printf("%s", "Hello world"),输出字符串 Hello world。 %c:将字符输出。例如:printf("%c", 'H'),输出字符 H。 %d:将十进制整数以带符号方式输出。例如:printf("%d", 123),输出整数 123。 %ld:将长整型以带符号方式输出。例如:printf("%ld", 123456L),输出长整型 123456。 %f:将浮点数以小数形式输出。例如:printf("%f", 3.14),输出浮点数 3.140000。 %e:将浮点数以指数形式输出。例如:printf("%e", 3.14),输出浮点数 3.140000e+00。 %x:将十六进制整数以无符号方式输出,并且以小写字母表示 a-f。例如:printf("%x", 255),输出十六进制整数 ff。 %X:将十六进制整数以无符号方式输出,并且以大写字母表示 A-F。例如:printf("%X", 255),输出十六进制整数 FF。 %u:将十进制整数以无符号方式输出。例如:printf("%u", 123),输出无符号整数 123。 %p:输出指针地址值。例如:printf("%p", &a),输出变量 a 的地址。 %o:将八进制形式输出一个整数。例如:printf("%o", 8),输出八进制数 10。 上面是 printf 函数中常用的格式说明符。此外,还有许多特殊的格式说明符,如:printf("%10d", 123),输出宽度为 10 的十进制整数 123,这里的 10 指定了输出的宽度。还有其它许多小技巧,需要在使用中逐渐积累。 需要注意的是,在使用 printf 函数时,格式说明符一定要与要输出的变量类型匹配,否则会造成输出错误。同时,在输出整数时,可以使用修正符号来指定输出的宽度和长度精度,这有助于我们得到更规范、美观的输出结果。 综合来看,printf 输出格式说明符是 C 程序中非常重要的部分,因此仔细学习使用,可以为我们的程序输出效果带来很大的改善。 ### 回答3: C语言中,printf函数是一种输入输出函数,它的主要作用是将参数输出到标准输出设备(stdout),即打印机或屏幕上。在使用printf函数输出时,需要使用格式说明符指定输出的格式,否则输出的内容将无法正确地显示在屏幕上。以下是C语言printf输出格式说明符的详解: 1. 字符类型(%c) %c用于输出单个字符,例如:printf("%c", 'A'); 则输出结果为"A"。 2. 整数类型(%d/%i) %d/%i用于输出以十进制形式表达的整数,例如:printf("%d", 100); 则输出结果为"100"。 3. 八进制类型(%o) %o用于输出以八进制形式表达的整数,例如:printf("%o", 100); 则输出结果为"144"。 4. 十六进制类型(%x/%X) %x/%X用于输出以十六进制形式表达的整数,其中%x输出结果为小写字母,%X输出结果为大写字母。例如:printf("%x", 100); 则输出结果为"64"。 5. 浮点数类型(%f) %f用于输出以小数形式表达的实数,例如:printf("%f", 3.1415926); 则输出结果为"3.141593"。 6. 科学计数法类型(%e/%E) %e/%E用于输出以科学计数法形式表达的实数,其中%e输出结果为小写字母,%E输出结果为大写字母。例如:printf("%e", 3.1415926); 则输出结果为"3.141593e+00"。 7. 字符串类型(%s) %s用于输出字符串,例如:printf("%s", "Hello World!"); 则输出结果为"Hello World!"。 8. 指针类型(%p) %p用于输出指针地址,例如:printf("%p", &a); 则输出结果为"0x7ffeeb4b345c"。 以上是C语言printf输出格式说明符的详解,掌握这些格式说明符可以更加灵活地输出内容。同时,在程序中使用printf函数时,需要注意输出格式和参数类型的匹配,否则会产生错误的结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值