printf函数格式化输出使用总结
2015-08-07 09:05
405 查看
printf函数称为格式输出函数,其关键字最末一个字母f即为“格式”(format)之意。其功能是按用户指定的格式,把指定的数据显示到显示器屏幕上。
printf函数是一个标准库函数,它的函数原型在头文件“stdio.h”中。但作为一个特例,不要求在使用
printf 函数之前必须包含stdio.h文件。printf函数调用的一般形式为:
printf(“格式控制字符串”, 输出表列)
其中格式控制字符串用于指定输出格式。格式控制串可由格式字符串和非格式字符串两种组成。格式字符串是以%开头的字符串,在%后面跟有各种格式字符,以说明输出数据的类型、形式、长度、小数位数等。如:
“%d”表示按十进制整型输出;
“%ld”表示按十进制长整型输出;
“%c”表示按字符型输出等。
非格式字符串原样输出,在显示中起提示作用。输出表列中给出了各个输出项,要求格式字符串和各输出项在数量和类型上应该一一对应。
在Turbo C中格式字符串的一般形式为:
[标志][输出最小宽度][.精度][长度]类型。
其中方括号[]中的项为可选项。
各项的意义介绍如下。
1) 类型
类型字符用以表示输出数据的类型,其格式符和意义如下表所示:
\f 换页
\n 换行
\r 回车
\t 制表符
\047 八进制47,即 单引号
\c c代表任一其他字符,例如”\“
printf 函数
转义字符 定义
c 字符
s 字符串
d 十进制整数
ld 十进制长整数
u 十进制无符号整数
lu 十进制无符号长整数
x 十六进制整数
lx 十六进制长整数
o 八进制整数
lo 八进制长整数
e 科学计数法表示浮点数
f 浮点数
g 选用e或f中较短的一种形式
printf 修饰符
字符 定义
- 左对齐修饰符
# 显示8进制整数时在前面加个0
显示16进制整数时在前面加0x
+ 显示使用d,e,f,g转换的整数时,加上正负号+ 或 -
0 用0而不用空白符来填充显示的值
printf的格式说明符
假定x='A' y=15 z=2.3 $1 = Bob Smith
格式说明符 功能
%c 打印单个ASCII字符
printf ("the character is %c\n",x)
输出:the character is A
%d 打印一个十进制整数
printf("ths boy is %d years old\n",y)
输出:the boy is 15 years old
%e 打印数字的e计数法形式
printf("z is %e\n",z)
输出: z is 2.3e+01
%f 打印一个浮点数
printf("z is %f\n",2.3*2)
输出: z is 4.600000
%o 打印数字的八进制值
printf ("z is %o\n",y)
输出:z is 17
%s 打印一个字符串
printf ("the name is %s\n",$1)
输出:the name is Bob Smith
%x 打印数字的十六进制
printf("y is %x\n",y)
输出:x is f
[cpp] view
plaincopyprint?
#include<stdio.h>
#include<string.h>
int main()
{
char c, s[20];
int a=1234;
float f=3.141592653589;
double x=0.12345678912345678;
strcpy(s, "Hello,World");
c='\x41';
printf("a=%d\n", a);//按照十进制整数格式输出,显示 a=1234
printf("a=%d%%\n", a);//输出%号 结果 a=1234%
printf("a=%6d\n", a);//输出6位十进制整数 左边补空格,显示 a= 1234
printf("a=%06d\n", a);//输出6位十进制整数 左边补0,显示 a=001234
printf("a=%2d\n", a);//a超过2位,按实际输出 a=1234
printf("a=%-6d\n", a);///输出6位十进制整数 右边补空格,显示 a=1234
printf("f=%f\n", f);//浮点数有效数字是7位,结果 f=3.141593
printf("f=6.4f\n", f);//输出6列,小数点后4位,结果 f=3.1416
printf("x=%lf\n", x);//输出长浮点数 x=0.123457
printf("x=%18.16lf\n", x);//输出18列,小数点后16位,x=0.1234567891234567
printf("c=%c\n", c); //输出字符 c=A
printf("c=%x\n", c);//以十六进制输出字符的ASCII码 c=41
printf("s[]=%s\n", s);//输出数组字符串s[]=Hello,World
printf("s[]=%6.9s\n", s);//输出最多9个字符的字符串 s[]=Hello,Wor
return 0;
}
printf函数调用的一般形式
printf函数是一个标准库函数,它的函数原型在头文件“stdio.h”中。但作为一个特例,不要求在使用printf 函数之前必须包含stdio.h文件。printf函数调用的一般形式为:
printf(“格式控制字符串”, 输出表列)
其中格式控制字符串用于指定输出格式。格式控制串可由格式字符串和非格式字符串两种组成。格式字符串是以%开头的字符串,在%后面跟有各种格式字符,以说明输出数据的类型、形式、长度、小数位数等。如:
“%d”表示按十进制整型输出;
“%ld”表示按十进制长整型输出;
“%c”表示按字符型输出等。
非格式字符串原样输出,在显示中起提示作用。输出表列中给出了各个输出项,要求格式字符串和各输出项在数量和类型上应该一一对应。
格式字符串
在Turbo C中格式字符串的一般形式为:[标志][输出最小宽度][.精度][长度]类型。
其中方括号[]中的项为可选项。
各项的意义介绍如下。
1) 类型
类型字符用以表示输出数据的类型,其格式符和意义如下表所示:
格式字符 | 意义 |
---|---|
d | 以十进制形式输出带符号整数(正数不输出符号) |
o | 以八进制形式输出无符号整数(不输出前缀0) |
x,X | 以十六进制形式输出无符号整数(不输出前缀Ox) |
u | 以十进制形式输出无符号整数 |
f | 以小数形式输出单、双精度实数 |
e,E | 以指数形式输出单、双精度实数 |
g,G | 以%f或%e中较短的输出宽度输出单、双精度实数 |
c | 输出单个字符 |
s | 输出字符串 |
二转义序列 含义
\b 退格\f 换页
\n 换行
\r 回车
\t 制表符
\047 八进制47,即 单引号
\c c代表任一其他字符,例如”\“
printf 函数
转义字符 定义
c 字符
s 字符串
d 十进制整数
ld 十进制长整数
u 十进制无符号整数
lu 十进制无符号长整数
x 十六进制整数
lx 十六进制长整数
o 八进制整数
lo 八进制长整数
e 科学计数法表示浮点数
f 浮点数
g 选用e或f中较短的一种形式
printf 修饰符
字符 定义
- 左对齐修饰符
# 显示8进制整数时在前面加个0
显示16进制整数时在前面加0x
+ 显示使用d,e,f,g转换的整数时,加上正负号+ 或 -
0 用0而不用空白符来填充显示的值
printf的格式说明符
假定x='A' y=15 z=2.3 $1 = Bob Smith
格式说明符 功能
%c 打印单个ASCII字符
printf ("the character is %c\n",x)
输出:the character is A
%d 打印一个十进制整数
printf("ths boy is %d years old\n",y)
输出:the boy is 15 years old
%e 打印数字的e计数法形式
printf("z is %e\n",z)
输出: z is 2.3e+01
%f 打印一个浮点数
printf("z is %f\n",2.3*2)
输出: z is 4.600000
%o 打印数字的八进制值
printf ("z is %o\n",y)
输出:z is 17
%s 打印一个字符串
printf ("the name is %s\n",$1)
输出:the name is Bob Smith
%x 打印数字的十六进制
printf("y is %x\n",y)
输出:x is f
[cpp] view
plaincopyprint?
#include<stdio.h>
#include<string.h>
int main()
{
char c, s[20];
int a=1234;
float f=3.141592653589;
double x=0.12345678912345678;
strcpy(s, "Hello,World");
c='\x41';
printf("a=%d\n", a);//按照十进制整数格式输出,显示 a=1234
printf("a=%d%%\n", a);//输出%号 结果 a=1234%
printf("a=%6d\n", a);//输出6位十进制整数 左边补空格,显示 a= 1234
printf("a=%06d\n", a);//输出6位十进制整数 左边补0,显示 a=001234
printf("a=%2d\n", a);//a超过2位,按实际输出 a=1234
printf("a=%-6d\n", a);///输出6位十进制整数 右边补空格,显示 a=1234
printf("f=%f\n", f);//浮点数有效数字是7位,结果 f=3.141593
printf("f=6.4f\n", f);//输出6列,小数点后4位,结果 f=3.1416
printf("x=%lf\n", x);//输出长浮点数 x=0.123457
printf("x=%18.16lf\n", x);//输出18列,小数点后16位,x=0.1234567891234567
printf("c=%c\n", c); //输出字符 c=A
printf("c=%x\n", c);//以十六进制输出字符的ASCII码 c=41
printf("s[]=%s\n", s);//输出数组字符串s[]=Hello,World
printf("s[]=%6.9s\n", s);//输出最多9个字符的字符串 s[]=Hello,Wor
return 0;
}
相关文章推荐
- MAC OS X 终端命令入门 (简单常用整理)
- Context的作用
- 源码推荐(8.07):快速创建Settings屏幕,icon间优雅的过渡
- Android中非常cool的API
- Android工作两年之后的第一个App--天真无谐
- 哈希-Gold Balanced Lineup
- HDU - 5358(思路优化)
- Array.sort()学习到的
- 哈希-Gold Balanced Lineup 分类: POJ 哈希 2015-08-07 09:04 2人阅读 评论(0) 收藏
- Maven error “Failure to transfer…”解决办法
- APNS-- IOS开发之实现App消息推送
- scikit-learn(工程中用的相对较多的模型介绍):1.13. Feature selection
- 简单下拉菜单
- Poj 3189 Steady Cow Assignment (多重匹配)
- tools:context与xmlns:tools学习笔记
- ioctl和struct ifreq
- MIPS ABI n32意味着什么?
- 35岁前成功的12条黄金法则
- POJ 1236 Network of Schools
- 报表打印FastReport.Ne