一、输出格式
在C语言中,printf 函数提供了多种输出格式,用于控制不同类型数据的输出方式。
1.整数输出格式
%d:以十进制形式输出整数。
%o:以八进制形式输出整数(无前导0)。
%x 或 %X:以十六进制形式输出整数(小写x表示小写字母,大写X表示大写字母)。
%u:以无符号十进制形式输出整数。
字段宽度和精度:可以在%和格式字符之间插入一个数字来指定字段宽度(即输出的最小宽度)(默认右对齐)如果数值的位数小于指定的字段宽度,那么输出将在左侧用空格填充。(除非使用了负号-,表示左对齐,这时将在右侧填充空格)。
2.浮点数输出格式
%f:以标准的小数形式输出浮点数。
%e 或 %E:以科学计数法形式输出浮点数(小写e表示小写字母,大写E表示大写字母)。
%g 或 %G:自动选择%f或%e格式中较短的一种输出,且不输出无意义的零。
字段宽度和精度:可以通过 %m.nf 的形式来指定输出的字段宽度 m 和小数点后的位数 n。如果省略 m,则宽度由系统决定;如果省略 n,则默认为6位小数。
3.字符输出格式
%c:输出一个字符。
字段宽度:可以使用 %mc 的形式来指定输出的字符宽度。如果字符的ASCII码值对应的字符宽度小于指定的宽度,则会在左侧或右侧(取决于是否使用-)填充空格以达到指定的宽度。
4.字符串输出格式
%s:输出一个字符串。
字段宽度和精度:可以通过 %ms、%-ms、%m.ns、%-m.ns 的形式来指定输出的字符串宽度和精度。m指定字段宽度,n指定从字符串左侧开始输出的字符数。如果省略n,则输出整个字符串。
5.其他
%n:将已打印字符数保存在整型指针所指向的变量中。这通常用于统计printf函数的输出字符数。
转义字符:如 \n(换行)、\t(制表符) 等,用于在输出中插入特殊字符。
6.修饰符
l 或 L:用于输出长整型(long)或长双精度浮点数(long double)。例如,%ld用于输出long型整数,%Lf:用于输出long double型浮点数。
h:用于输出短整型(short)。例如,%hd用于输出short型整数。
7.标志
-:左对齐输出。
+:对于整数,总是输出符号(正号或负号)。
空格:对于整数,如果为正数,则在其前面加一个空格;如果为负数,则输出负号。
#:对于o(八进制)和x(十六进制)格式,总是在输出的数前面加上0或0x/0X前缀。
这些输出格式和修饰符可以组合使用,以控制 printf 函数的输出格式。
二、占位输出
在C语言中,使用printf函数时,可以通过格式说明符来指定输出的位数。对于整数,可以使用字段宽度和精度说明符来控制输出的格式。虽然精度通常用于浮点数,但字段宽度对于整数和浮点数都是有用的。对于整数,可以使用%d、%x或%o等来说明符,并在它们前面添加一个数字来指定字段的最小宽度。如果数值的位数小于指定的字段宽度,那么输出将在左侧用空格填充(除非使用了负号-,表示左对齐,这时将在右侧填充空格)。
整型:
%2d:如果数值的位数小于指定的字段宽度,那么输出将在左侧用空格填充%02d:如果数值的位数小于指定的字段宽度,那么输出将在左侧用0填充
指定字段宽度(右对齐)
#include <stdio.h> int main(void) { int num = 255; printf("Decimal: %5d\n", num); // 输出:Decimal: 255(前面有2个空格) printf("Hexadecimal: %8x\n", num); // 输出:Hexadecimal: ff(前面有6个空格) printf("Decimal: %05d\n", num); // 输出:Decimal: 255(前面有2个0) printf("Hexadecimal: %08x\n", num); // 输出:Hexadecimal: ff(前面有6个0) return 0; }
指定字段宽度并左对齐
#include <stdio.h> int main(void) { int num = 255; printf("1:右对齐,不足左侧补0\n"); printf("Decimal:\n%05d\n", num); // 输出:Decimal: 255(前面有2个0) printf("Hexadecimal:\n%08x\n", num); // 输出:Hexadecimal: ff(前面有6个0) printf("2:右对齐,不足左侧补空格\n"); printf("Decimal:\n%5d\n", num); // 输出:Decimal: 255(前面有2个空格) printf("Hexadecimal:\n%8x\n", num); // 输出:Hexadecimal: ff(前面有6个空格) printf("3:左对齐,不足右侧补空格\n"); printf("Decimal:\n%-5d\n", num); // 输出:Decimal: 255 (后面有2个空格) printf("Hexadecimal:\n%-8x\n", num); // 输出:Hexadecimal: ff (后面有6个空格) return 0; }
对于浮点数,可以同时指定字段宽度和精度
精度用于指定小数点后的位数,而字段宽度用于指定整个数字(包括小数点和符号)的最小宽度。
#include <stdio.h> int main(void) { float pi = 3.14159265; printf("Pi:%7.2f\n", pi); // 输出:Pi:0003.14(整个数字宽度为7,小数点后有2位)右对齐 printf("Pi:%07.2f\n", pi); // 输出:Pi: 3.14(整个数字宽度为7,小数点后有2位)右对齐 printf("Pi:%-7.2f\n", pi); // 输出:Pi:3.14 (整个数字宽度为7,小数点后有2位)左对齐 return 0; }
使用 * 作为字段宽度或精度的占位符
使用 * 作为字段宽度或精度的占位符,并在 printf 的参数列表中提供一个整数来指定实际的宽度或精度。允许在运行时动态地设置这些值。
#include <stdio.h> int main(void) { int num = 255; int width = 8; printf("Decimal:%0*d\n", width, num); // 输出:Decimal: 255(前面有5个0) printf("Decimal:%*d\n", width, num); // 输出:Decimal: 255(前面有5个空格) printf("Hexadecimal:%0*x\n", width, num); // 输出:Hexadecimal: ff(前面有6个0) printf("Hexadecimal:%*x\n", width, num); // 输出:Hexadecimal: ff(前面有6个空格) printf("Decimal:%-*d\n", width, num); // 输出:Decimal: 255(后面5个空格) printf("Hexadecimal:%-*x\n", width, num); // 输出:Hexadecimal: ff(后面有6个空格) return 0; }//在这个例子中,%*x 中的 * 表示字段宽度将从参数列表中获取,即width变量的值。
其它,分配一个足够大的字符串并打印字符串格式内容
#include <stdio.h>#include <stdlib.h>#include <stdarg.h>#include <string.h>char *make_message(const char *fmt, ...){ int size = 0; char *p = NULL; va_list ap; /* Determine required size */ va_start(ap, fmt); size = vsnprintf(p, size, fmt, ap); va_end(ap); if (size < 0) return NULL; size++; /* For '\0' */ p = malloc(size); if (p == NULL) return NULL; va_start(ap, fmt); size = vsnprintf(p, size, fmt, ap); va_end(ap); if (size < 0) { free(p); return NULL; } return p;}int main(int argc,char *argv[]) { char *p=make_message(argv[1]); if(p !=NULL) {printf("%d\n%*s\n",(int)strlen(p),(int)strlen(p),p); } return 0; }