C语言printf()函数:格式化输出函数
头文件:#include <stdio.h>
printf()函数是最常用的格式化输出函数,其原型为:
int printf( char * format, ... );
printf()会根据参数 format 字符串来转换并格式化数据,然后将结果输出到标准输出设备(显示器),直到出现字符串结束('\0')为止。
参数 format 字符串可包含下列三种字符类型:
格式转换为一个百分比符号(%)及其后的格式字符所组成。一般而言,每个%符号在其后都必需有一个参数与之相呼应(只有当%%转换字符出现时会直接输出%字符),而欲输出的数据类型必须与其相对应的转换字符类型相同。
printf()格式转换的一般形式如下:
%(flags)(width)(. prec)type
以括号括起来的参数为选择性参数,而%与type 则是必要的,下面介绍 type 的几种形式。
1) 整数
2) 字符及字符串
prec 有几种情况:
width 为参数的最小长度,若此栏并非数值,而是*符号,则表示以下一个参数当做参数长度。
flags 有下列几种情况
【返回值】成功则返回写入的字符数目。
如果发生写入错误,将会设置文件错误标志(可通过 ferror() 检测),并返回一个负数。
如果在写入宽字符时一个多字节的字符发生编码错误,那么 errno 将被设置为 EILSEQ,并返回一个负数。
printf( format, ... ) 等价于 fprintf(stdout, format, ...),更多信息请参考 fprintf() 函数。
【实例】分别输出整数、浮点数和字符串。
【运行结果】
1 4.4 fs
int is:1
float is:4.400000
char is:fs
例子首先是等待用户输入整数浮点数和一个字符串,然后调用函数printf()按照对应的格式输出。
又如,输出更多格式的数据。
Characters: a A
Decimals: 1977 650000
Preceding with blanks: 1977
Preceding with zeros: 0000001977
Some different radices: 100 64 144 0x64 0144
floats: 3.14 +3e+000 3.141600E+000
Width trick: 10
A string
printf()函数是最常用的格式化输出函数,其原型为:
int printf( char * format, ... );
printf()会根据参数 format 字符串来转换并格式化数据,然后将结果输出到标准输出设备(显示器),直到出现字符串结束('\0')为止。
参数 format 字符串可包含下列三种字符类型:
- 一般文本,将会直接输出
- ASCII 控制字符,如\t、\n 等有特定含义
- 格式转换字符
格式转换为一个百分比符号(%)及其后的格式字符所组成。一般而言,每个%符号在其后都必需有一个参数与之相呼应(只有当%%转换字符出现时会直接输出%字符),而欲输出的数据类型必须与其相对应的转换字符类型相同。
printf()格式转换的一般形式如下:
%(flags)(width)(. prec)type
以括号括起来的参数为选择性参数,而%与type 则是必要的,下面介绍 type 的几种形式。
1) 整数
- %d 整数的参数会被转成有符号的十进制数字
- %u 整数的参数会被转成无符号的十进制数字
- %o 整数的参数会被转成无符号的八进制数字
- %x 整数的参数会被转成无符号的十六进制数字,并以小写abcdef 表示
- %X 整数的参数会被转成无符号的十六进制数字,并以大写ABCDEF 表示浮点型数
- %f double 型的参数会被转成十进制数字,并取到小数点以下六位,四舍五入
- %e double 型的参数以指数形式打印,有一个数字会在小数点前,六位数字在小数点后,而在指数部分会以小写的e 来表示
- %E 与%e 作用相同,唯一区别是指数部分将以大写的E 来表示
- %g double 型的参数会自动选择以%f 或%e 的格式来打印,其标准是根据打印的数值及所设置的有效位数来决定。
- %G 与%g 作用相同,唯一区别在以指数形态打印时会选择%E 格式。
2) 字符及字符串
- %c 整型数的参数会被转成unsigned char 型打印出
- %s 指向字符串的参数会被逐字输出,直到出现NULL 字符为止
- %p 如果是参数是"void *"型指针则使用十六进制格式显示
prec 有几种情况:
- 正整数的最小位数
- 在浮点型数中代表小数位数
- 格式代表有效位数的最大值
- 在%s 格式代表字符串的最大长度
- 若为×符号则代表下个参数值为最大长度
width 为参数的最小长度,若此栏并非数值,而是*符号,则表示以下一个参数当做参数长度。
flags 有下列几种情况
- + 一般在打印负数时,printf ()会加印一个负号,整数则不加任何负号,此旗标会使得在打印正数前多一个正号 (+)。
- # 此旗标会根据其后转换字符的不同而有不同含义。当在类型为o 之前 (如%#o),则会在打印八进制数值前多印一个o。而在类型为x 之前 (%#x)则会在打印十六进制数前多印'0x',在型态为e、E、f、g 或G 之前则会强迫数值打印小数点。在类型为g 或G 之前时则同时保留小数点及小数位数末尾的零。
- 0 当有指定参数时,无数字的参数将补上0。默认是关闭此旗标,所以一般会打印出空白字符。
【返回值】成功则返回写入的字符数目。
如果发生写入错误,将会设置文件错误标志(可通过 ferror() 检测),并返回一个负数。
如果在写入宽字符时一个多字节的字符发生编码错误,那么 errno 将被设置为 EILSEQ,并返回一个负数。
printf( format, ... ) 等价于 fprintf(stdout, format, ...),更多信息请参考 fprintf() 函数。
【实例】分别输出整数、浮点数和字符串。
#include<stdio.h> int main(void) { int a=1; float b=5.0; char str[100]= ""; scanf("%c %c %c",&a,&b,str); /*分别演示 整数*/ printf("int is:%d\n",a); /*分别演示 浮点数*/ printf("float is:%f\n",b); /*分别演示 字符串*/ printf("char is:%s\n",str); return 0; }输出结果:
【运行结果】
1 4.4 fs
int is:1
float is:4.400000
char is:fs
例子首先是等待用户输入整数浮点数和一个字符串,然后调用函数printf()按照对应的格式输出。
又如,输出更多格式的数据。
#include <stdio.h> int main() { printf ("Characters: %c %c \n", 'a', 65); printf ("Decimals: %d %ld\n", 1977, 650000L); printf ("Preceding with blanks: %10d \n", 1977); printf ("Preceding with zeros: %010d \n", 1977); printf ("Some different radices: %d %x %o %#x %#o \n", 100, 100, 100, 100, 100); printf ("floats: %4.2f %+.0e %E \n", 3.1416, 3.1416, 3.1416); printf ("Width trick: %*d \n", 5, 10); printf ("%s \n", "A string"); return 0; }输出结果:
Characters: a A
Decimals: 1977 650000
Preceding with blanks: 1977
Preceding with zeros: 0000001977
Some different radices: 100 64 144 0x64 0144
floats: 3.14 +3e+000 3.141600E+000
Width trick: 10
A string