C语言中输入输出所有格式控制符

 最近在重温C语言,发现C语言的输入输出函数scanf和printf函数在控制输入输出时有许多控制符来控制输入输出数据的格式。于是就打算来整理一下。

参考百度百科词条

 scanf()是C语言中的一个输入函数。与printf函数一样,都被声明在头文件stdio.h里。它是格式输入函数,即按用户指定的格式从键盘上把数据输入到指定的变量之中。

 printf命令的作用是格式化输出函数,一般用于向标准输出设备按规定格式输出信息。printf()函数的调用格式为:printf(”<格式化字符串>”, <参量表>)。printf()是C语言标准库函数,在 stdio.h 中定义。输出的字符串除了可以使用字母、数字、空格和一些数字符号以外,还可以使用一些转义字符表示特殊的含义。

函数定义

 int printf(char *format…);
 int scanf(const char * restrict format,…);

函数返回值

 printf 函数的返回值为printf实际控制输出的字符数。
 scanf函数返回成功读入的数据项数,读入数据时遇到了“文件结束”则返回EOF。

格式控制字符串format

 printf的格式控制字符串format组成如下:

%[flags][width][.prec][length]type

 即:%[标志][最小宽度][.精度][类型长度]类型控制符
 详解见下文。

用法详解

 通常意义上format的格式如下:[]里的内容表示可选,即可带可不带。

%[flags][width][.prec][length]type

 规定输出数据的格式,具体如下:[1]

类型控制符type

 type的字符用于规定输出数据的类型,含义如下:

字符 对应数据类型 含义
d / i int 接受整数值并将它表示为有符号的十进制整数,i是老式写法
o unsigned int 无符号8进制整数(不输出前缀0)
u unsigned int 无符号10进制整数
x / X unsigned int 无符号16进制整数,x对应的是abcdef,X对应的是ABCDEF(不输出前缀0x)
f(lf) double 单精度浮点数和双精度浮点数用f(lf 在C99开始加入标准,意思和 f 相同)
e / E double 科学计数法表示的数,基数为10,此处”e”的大小写代表在输出时用的”e”的大小写
a /A double 16进制科学计数法表示的数,基数为2,以p表示,以16进制输出,此处”a”的大小写代表在输出时用的”p”的大小写
g / G double 有效位数,如:%.8g表示单精度浮点数保留8位有效数字
c char 字符型。可以把输入的数字按照ASCII码相应转换为对应的字符
s / S char * / wchar_t * 字符串。输出字符串中的字符直至字符串中的空字符(字符串以’\0’结尾,这个’\0’即空字符)
p void * 以16进制形式输出指针
n int * 到此字符之前为止,一共输出的字符个数,不输出文本
% 无输入 不进行转换,输出字符‘%’(百分号)本身
m 打印errno值对应的出错内容,(例: printf(“%m\n”); )

 注:%g、%G在小数点位数四位或指数大于等于精度时用%e、%E,否则用%f。

标志flags

 flags规定输出样式,取值和含义如下:

字符 字符名称 说明
- 减号 左对齐,右边填充空格(默认右对齐)
+ 加号 在数字前增加符号 + 或 -
0 数字零 将输出的前面补上0,直到占满指定列宽为止(不可以搭配使用”-“)
空格 输出值为正时加上空格,为负时加上负号
# 井号 type是o、x、X时,增加前缀0、0x、0X;type是e、E、f、g、G时,一定使用小数点;type是g、G时,尾部的0保留
示例:
printf("%5d\n",1000); //默认右对齐,左边补空格
printf("%-5d\n",1000); //左对齐,右边补空格
printf("%+d %+d\n",1000,-1000); //输出正负号
printf("% d % d\n",1000,-1000);//正号用空格替代,负号输出
printf("%x %#x\n",1000,1000); //输出0x
printf("%.0f %#.0f\n",1000.0,1000.0)//当小数点后不输出值时依然输出小数点
printf("%g %#g\n",1000.0,1000.0); //保留小数点后后的0
printf("%05d\n",1000); //前面补0

输出最小宽度width

 用于控制显示数值的宽度,取值和含义如下:

 n(n=1,2,3,4,5,6…): 宽度至少为n位,不够以空格填充。

&esmp;* 格式列表中,下一个参数还是width

 width是一个可选的指定最小值字段宽度的十进制数字字符串。如果转换值字符少于字段宽度,该字段将从左到右按指定的字段宽度填充。如果指定了左边调整选项,字段将在右边填充。如果转换结果宽于字段宽度,将扩展该字段以包含转换后的结果。不会发生截断。然而,小的精度可能导致在右边发生截断。

精度.prec

 用于控制小数点后面的位数,取值和含义如下:

 无按缺省精度显示0
 当type=d,i,o,u,x时,没有影响;
 type=e,E,f时,不显示小数点
 n(n=1,2,3…)
 当type=e,E,f时表示的最大小数位数;
 type=其他,表示显示的最大宽度
 prec是指可选的精度。精度是一个.(点)后跟十进制数字字符串。如果没有给出精度,按 0(零)对待。精度指定:

  • * d、o、i、 u、x 或 X 转换的最少数字显示位数。
  • * e 和 f 转换的基数字符后的最少数字显示位数。
  • * g 转换的最大有效数字位数。
  • * s 转换中字符串的最大打印字节数目。

类型长度length

 类型长度指明待输出数据的长度。因为相同类型可以有不同的长度,比如整型有16bits的short int,32bits的int,也有64bits的long int,浮点型有32bits的单精度float和64bits的双精度double。为了指明同一类型的不同长度,类型长度(length)应运而生,成为格式控制字符串的一部分。

length 描述
h 参数被解释为短整型或无符号短整型(仅适用于整数说明符:i、d、o、u、x 和 X)。
l 参数被解释为长整型或无符号长整型,适用于整数说明符(i、d、o、u、x 和 X)及说明符 c(表示一个宽字符)和 s(表示宽字符字符串)。
L 参数被解释为长双精度型(仅适用于浮点数说明符:e、E、f、g 和 G)。

 根据不同的 format 字符串,函数可能需要一系列的附加参数,每个参数包含了一个要被插入的值,替换了 format 参数中指定的每个 % 标签。参数的个数应与 % 标签的个数相同。 [2]

转义序列

 这些转义序列在字符串中会被自动转换为相应操作命令。使用的常见转义字符如下:

符号 意义 符号 意义
\a 铃声(提醒) \b Backspace
\f 换页 \n 换行
\r 回车 \t 水平制表符
\v 垂直制表符 \’ 单引号
\” 双引号 \\ 反斜杠
? 文本问号 \ooo(例如\024) ASCII字符(OCX)
\xhh (例如:\x20) ASCII字符(HEX) \xhhhh 宽字符(2字节HEX)

 例如,WCHAR f = L’\x4e00’ 或 WCHAR b[] = L”The Chinese character for one is \x4e00”。

[1]Brian W.Kernighan,Dennis M.Ritchie.C程序设计语言.中国:机械工业出版社,2004年1月1日:221-222
[2]Stephen Prata.C Primer Plus(第五版):人民邮电出版社,2005年2月1日