C语言格式化输入输出
格式字符串的一般形式:[标志][输出最小宽度][. 精度][长度] 类型 (其中方括号[] 中的项为可选项。)
各项意义:
1) 类型:类型字符用以表示输出数据的类型,其格式符和意义如下表所示:
格式字符 | 意义 |
d | 以十进制形式输出带符号整数(正数不输出符号) |
o | 以八进制形式输出无符号整数(不输出前缀 0) |
x,X | 以十六进制形式输出无符号整数(不输出前缀 Ox) |
u | 以十进制形式输出无符号整数 |
f | 以小数形式输出单、双精度实数 |
e,E | 以指数形式输出单、双精度实数 |
g,G | 以%f 或%e 中较短的输出宽度输出单、双精度实数 |
c | 输出单个字符 |
s | 输出字符串 |
2) 标志:标志字符为-、 +、 #、空格四种,其意义下表所示:
标 志 | 意义 |
- | 结果左对齐,右边填空格 |
+ | 输出符号(正号或负号) |
空格 | 输出值为正时冠以空格,为负时冠以负号 |
# | 对 c,s,d,u 类无影响;对 o 类, 在输出时加前缀 o;对 x 类, 在输出时加前缀 0x; 对 e,g,f 类当结果有小数时才给出小数点 |
3) 输出最小宽度: 用十进制整数来表示输出的最少位数。若实际位数多于定义的宽度,则按实际位数输出,若实际位数少于定义的宽度则补以空格或 0。
4) 精度: 精度格式符以“. ”开头,后跟十进制整数。本项的意义是:如果输出数字,则表示小数的位数;如果输出的是字符,则表示输出字符的个数;若实际位数大于所定义的精度数,则截去超过的部分。
5) 长度: 长度格式符为 h,l 两种, h 表示按短整型量输出, l 表示按长整型量输出。
scanf:
格式字符串的一般形式:%[*][输入数据宽度][长度] 类型 (其中有方括号[] 的项为任选项。)
各项意义:
1) 类型:表示输入数据的类型,其格式符和意义如下表所示。
格式字符 | 意义 |
d | 输入十进制整数 |
o | 输入八进制整数 |
x | 输入十六进制整数 |
u | 输入无符号十进制整数 |
f,e | 输入实型数(用小数形式或指数形式) |
c | 输入单个字符 |
s | 输入字符串 |
2) “ *”符: 用以表示该输入项读入后不赋予相应的变量,即跳过该输入值。
例:scanf("%d %*d %d",&a,&b);
输入: 1 2 3, 则a=1,2被跳过,b=3。
3) 宽度: 用十进制整数指定输入的宽度(即字符数) 。
例1:scanf("%5d",&a);
输入: 12345678 则a=12345,其余部分被截去。
例2:scanf("%4d%4d",&a,&b);
输入: 12345678 则a=1234,b=5678。
4) 长度: 长度格式符为 l 和 h, l 表示输入长整型数据(如%ld) 和双精度浮点数(如%lf) 。 h 表示输入短整型数据。
另外在使用 scanf 时还必须注意以下几点:
1. scanf 函数中没有精度控制,如: scanf("%5.2f",&a); 是非法的。不能企图用此语句输入小数部分为2位的实数。
2. 在输入多个数值数据时,若格式控制串中没有非格式字符作输入数据之间的间隔则可用空格, TAB或回车作间隔。 C 编译在碰到空格,TAB,回车或非法数据(如对“%d”输入“12A”时, A 即为非法数据)时即认为该数据结束。
3. 在输入字符数据时,若格式控制串中无非格式字符,则认为所有输入的字符均为有效字符。
例:scanf("%c%c%c",&a,&b,&c);
输入:d e f 则a='d', b=' ', c='e'。
输入:def 则a='d', b='e', c='f'。
如果在格式控制中加入空格作为间隔,如:scanf ("%c %c %c",&a,&b,&c);则输入时各数据之间可加空格。
4. 如果格式控制串中有非格式字符则输入时也要输入该非格式字符。
例1:scanf("%d,%d,%d",&a,&b,&c); (其中用非格式符“ , ”作间隔符)
输入应为:5,6,7
例2:scanf("a=%d,b=%d,c=%d",&a,&b,&c);
输入应为:a=5,b=6,c=7
5. 如输入的数据与输出的类型不一致时,虽然编译能够通过,但结果将不正确。
double型输入输出形式如下:
double a;
scanf("%lf",&a);
printf("%f",a);
注:在输入double类型时需要使用%lf才能正常得到a值,而在输出double类型时可以使用%f,因为在执行printf("%f",a)时编译器将自动把float类型的参数转化为double类型