C语言Ⅰ_输入输出格式化

输入输出格式化

printf()格式化输出

1
printf("控制格式",<参数>,<参数>)

C中填充字符可以为0、空格,不能为字母、符号等

C++中才添加了数字、字母、符号等占位

1
2
3
4
//控制格式部分
[填充字符]%[对齐方式][标志][字段宽度][.精度][长度修饰符]修饰符
//或者为
%[*][域宽][长度][类型]
printf()修饰符01
printf()修饰符02

转换说明修饰符

这里需要注意,转换说明修饰符是将内存中二进制数据转换成对应格式的数据输出,而不是替换掉内存中原有数据。

修饰符 输出
%a,%A 浮点数、十六进制数和p-计数法(C99)
%c 单个字符
%d 有符号十进制数
%e, %E 浮点数的科学计数法
%f, %lf 浮点数,十进制计数法
%g, %G 根据数值不同自动选择%f或%e,%e格式在指数小于-4或者大于等于精度时使用
%i 有符号十进制整数(与%d相同)
%o 无符号八进制整数
%p 指针
%s 字符串
%u 无符号十进制数
%x, %X 使用十六进制数0f的无符号十六进制整数
%% 打印一个百分号

长度修饰符

长度修饰符 意义
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)示例: "%lld","%8llu"
L 浮点数修饰符一起使用,表示一个long double值示例: "%Lf", "%10.4Le"
t 整数修饰符一起使用,表示一个ptrdiff_t值(与两个指针之间的差相对应的类型)(C99)示例: "%td", "%1ti"
z 整数修饰符一起使用,表示一个size_t值(sizeof返回的类型)(C99)示例: "%zd","%12zx"

标志

标志 意义
- 项目左对齐,即,会把项目打印在字段的左侧开始处示例: "%-20s"
+ 有符号的值若为正,则显示带加号的符号;若为负,则显示带减号的符号示例: "%+6.2f"
(空格) 有符号的值若为正,则显示时带前导空格(但是不显示符号);若为负,则带减号符号。+标志会覆盖空格标志示例: "% 6.2f"
# 使用转换说明的可选形式。若为%o格式,则以0开始;若为%x和%Xgeshi ,则以0x或0X开始。对于所有的浮点形式,#保证了即使不跟任何数字,也打印一个小数点字符。对于%g和%G格式,它防止尾随0被删除示例: "%#o", "%#8.0f", "%+#10.3E"
0 对于所有的数字格式,用前导零而不是空格填充字段宽度。如果出现-标志或者指定了精度(对于整数)则忽略该标志示例: "%010d", "%08.3f","%02X"

示例

  • d/i:十进制,带符号整数
    • %d:按实际长度输出;
    • %[m]d:[m]域宽,整数,默认右对齐;(如果字符串本身长度大于m,则突破m的限制,将字符串全部输出;若串长小于m,则左补空格。)
    • %-[m]d左对齐
    • %ld:长整型数据;
  • o:八进制,无符号整数(不需要输入前缀o)
    • %o
    • %[m]o
    • %-[m]o
    • %lo
  • x:十六进制,无符号整数(不需要输入前缀ox)
    • %x
    • %[m]x
    • %-[m]x
    • %lx
  • s:字符串
    • %s
    • %[m]s
    • %-[m]s
    • %[m].[n]s:域宽为[m],取字符串左端[n]个字符,默认右对齐
    • %-[m].[n]s:域宽为[m],取字符串左端[n]个字符,左对齐
  • f:单、双精度实数
    • %f
    • %[m].[n]f:域宽为[m],取[n]位小数,默认右对齐
    • %-[m].[n]f:域宽为[m],取[n]位小数,左对齐
  • e:指数形式输出floatdouble
    • %e
    • %[m].[n]e
    • %-[m].[n]e
1
printf("%-10.2s, %10.5f, %10.3e, %+3i, %d","Hello",1.0090909,1.0090909,a,b);

scanf()格式化输入

1
scanf("控制格式", &<变量名>, &<变量名>)

除格式控制符外,其余字符需要原样输入,以达到控制输入字符格式的目的:

1
2
3
4
scanf("(%d,%d)",&a,&b)

input:(1,2)
output:a=1,b=2

printf() scanf()注意事项

  1. 读入double类型的数据时,使用%ld类型说明符;

C++