您的位置:首页 > 编程语言 > C语言/C++

C语言输出格式(详细)

2013-06-04 13:39 363 查看
C语言格式化输出
一、printf()函数
printf()函数是格式化输出函数,一般用于向标准输出设备按规定格式输出信息。在编写程序时经常会用到此函数。printf()函数的调用格式为: printf("<格式化字符串>", <参量表>);

其中格式化字符串包括两部分内容:一部分是正常字符, 这些字符将按原样输出, 另一部分是格式化规定字符,以"%"开始,后跟一个或几个规定字符用来确定输出内容格式。

参量表是需要输出的一系列参数,其个数必须与格式化字符串所说明的输出参数个数一样多,各参数之间用","分开,且顺序一一对应,否则将会出现意想不到的错误。
二、 格式化规定符

Turbo C2.0提供的格式化规定符如下:

━━━━━━━━━━━━━━━━━━━━━━━━━━

符号 作用

——————————————————————————

%d 十进制有符号整数

%u 十进制无符号整数

%f 浮点数

%s 字符串

%c 单个字符

%p 指针的值

%e 指数形式的浮点数

%x, %X 无符号以十六进制表示的整数

%0 无符号以八进制表示的整数

%g 自动选择合适的表示法

━━━━━━━━━━━━━━━━━━━━━━━━━━
可以在"%"和字母之间插进数字表示最大场宽。
三、规定符说明
说明1:对于d%
(1)%md: 指定输出的宽度。数据位数小于m,左端补空格;大于m,按实际位数输出。比如说%3d 表示输出3位整型数,不够3位右对齐。
a=123;b=12345;

printf("%4d,%4d",a,b);

输出结果为:_123,12345
若想在输出值前加一些0, 就应在场宽项前加个0。例如%04d表示在输出一个小于4位的数值时,将在前面补0使其总宽度为4位。
(2)%ld: 输出长整型数据。比如下面的就不能用%d。
long a=123456;

printf("%ld",a);

printf("%9ld",a); 输出结果为:___123456
(3)%-md:
可以控制输出左对齐,即在"%"和字母之间加入一个"-" 号可,没有说明则右对齐。

比如:%-7d 表示输出7位整数左对齐
说明2:对于f%
(1)%m.nf
表示最大场宽m,小数位为n位,整数位则为m-n-1位,够m位右对齐。
比如:%9.2f 表示输出场宽为9的浮点数, 其中小数位为2,整数位为6,小数点占一位,不够9位右对齐。
(2)%-m.nf可以控制输出左对齐。
(3)%lf 表示输出double浮点数。
说明3:对于%s,%e同样道理
%-10s 表示输出10个字符左对齐,没有说明则右对齐。

%8s 表示输出8个字符的字符串,不够8个字符右对齐。

%6.9s 表示显示一个长度不小于6且不大于9的字符串。若大于9,则第9个字符以后的内容将被删除。
说明4:其它注意
(1)超过说明的场宽
如果字符串的长度或整型数位数超过说明的场宽,将按其实际长度输出。对浮点数,若整数部分位数超过了说明的整数位宽度,将按实际整数位输出。若小数部分位数超过了说明的小数位宽度,则按说明的宽度以四舍五入输出。
(2)浮点数表示字符或整型量的输出格式,如%6.9s 和%6.9d

如果用浮点数表示字符或整型量的输出格式,小数点后的数字代表最大宽度,小数点前的数字代表最小宽度。若大于最大宽度,则最大宽度以后的内容将被删除。
比如: %6.9s 表示显示一个长度不小于6且不大于9的字符串。若大于9,则第9个字符以后的内容将被删除。
四、一些特殊字符
━━━━━━━━━━━━━━━━━━━━━━━━━━

字符 作用

——————————————————————————

\n 换行

\f 清屏并换页

\r 回车

\t Tab符

\xhh 表示一个ASCII码用16进表示,

其中hh是1到2个16进制数

━━━━━━━━━━━━━━━━━━━━━━━━━━
具体实现如下:
//%d 十进制有符号整数
//%u 十进制无符号整数
//%f 浮点数
//%s 字符串
//%c 单个字符
//%p 指针的值
//%e 指数形式的浮点数
//%g 自动选择合适的表示法
#include <iostream>
#include <stdio.h>
#include <stdlib.h>
using namespace std;

int main()
{
unsigned int a=23;
int b=234,h=4567;
double c=5.656;
long d=54;
float e=34.123456;
char f='a';
char g[10]={'a','c','c','e','p','t','e','d'};
int *p=&b;
//%md: 指定输出的宽度。数据位数小于m,左端补空格;大于m,按实际位数输出
//比如说%3d 表示输出3位整型数,不够3位右对齐,输出结果为:____23
printf("指定输出的宽度输出:a=%4d\n",a);
//%ld: 输出长整型数据
printf("输出长整型数据:d=%ld\n",d);
printf("指定输出的宽度输出长整型数据:d=%9ld\n",d);
//%-md:可以控制输出左对齐,即在"%"和字母之间加入一个"-" 号可,没有说明则右对齐。
printf("输出左对齐: b=%4d\n",b);
printf("输出左对齐: h=%4d\n",h);
//%m.nf,表示最大场宽m,小数位为n位,整数位则为m-n-1位,够m位右对齐。
printf("场宽m为9,小数为3位输出: e=%9.3f\n",e);
//%-m.nf可以控制输出左对齐
printf("场宽m为9,小数为3位,左对齐输出为: e=%9.3f\n",e);
//%.nf,表示小数位为n位
printf("小数为4位输出: e=%.4f\n",e);
//%lf 表示输出double浮点数
printf("double浮点数保留两位小数输出: c=%.2f\n",c);
//%10s 表示输出6个字符的字符串,不够6个字符右对齐。
printf("控制字符串6个字符的输出: g=%.6s\n",g);
//%c单个字符输出
printf("单个字符输出: f=%c\n",f);
//%p 输出指针的值
printf("指针的值输出: p=%p\n",p);
//%e 指数形式的浮点数
printf("指数形式的浮点数输出: e=%e\n",e);
//%g 自动选择合适的表示法
printf("double浮点数自动选择合适的表示法输出: c=%g\n",c);
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: