C语言 格式化输出--%m.n
格式字符:格式字符用以指定输出项的数据类型和输出格式。
①d格式:用来输出十进制整数(int)。有以下几种用法: %d:按整型数据的实际长度输出。 %m.nd:m为指定的输出字段的宽度,n定义为实际输出的个数。 m>0时为右对齐,根据n的大小,不足在左边补0; m<0时和m>0好像没有区别; 如果省略m或者n,则m=n; 如果只有m且不指定空位填0,根据m的正负值,空位以空格补齐。
int main(void) { int a = 123; printf("m.nd : %5.5d\n", a); //打印 00123 printf("-m.nd : %-5.5d\n", a); //打印 00123 printf(".nd : %.5d\n", a); //打印 00123 printf("m.d : %5.d\n", a); //打印 123 printf("md : %5d\n", a); //打印 123 printf("md : %05d\n", a); //指定空位补0:打印 00123 system("pause"); return EXIT_SUCCESS; }
o格式:以无符号八进制形式输出整数。对长整型(long)可以用"%lo"格式输出。同样也可以指定字段宽度用“%mo”格式输出。
int a = 9; printf("a=%o \n", a); //打印 11 = 1 * 8^0 + 1 * 8^1 system("pause"); return EXIT_SUCCESS;
x格式:以无符号十六进制形式输出整数。对长整型可以用"%lx"格式输出。同样也可以指定字段宽度用"%mx"格式输出。 u格式:以无符号十进制形式(unsigned int)输出整数。对长整型(unsigned long)可以用"%lu"格式输出。unsigned short 对应%hu。同样也可以指定字段宽度用“%mu”格式输出。 c格式:输出一个字符。
%s:例如:printf("%s", "CHINA") //输出"CHINA"字符串(不包括双引号) %ms:输出的字符串占m列,如果字符串本身长度大于m,则突破获m的限制,将字符串全部输出。若串长小于m,则左补空格。 %-ms:如果串长小于m,则在m列范围内,字符串向左靠,右补空格。 %m.ns:输出占m列,但只取字符串中左端n个字符。这n个字符输出在m列的右侧,左补空格。 %-m.ns:其中m、n含义同上,n个字符输出在m列范围的左侧,右补空格。如果n>m,则自动取n值,即保证n个字符正常输出。
#include <stdio.h> #include <stdlib.h> #include <string.h> void test() { char* str = "hello world !"; /* %ms:输出的字符串占m列,如果字符串本身长度大于m,则突破获m的限制,将字符串全部输出。 */ printf("1 = %5s \n", str); //打印 hello world ! /* 若串长小于m,则左补空格 */ printf("2 = %20s \n", str); //打印 空格hello world ! /* 输出占m列,但只取字符串中左端n个字符。这n个字符输出在m列的右侧,左补空格。 */ printf("3 = %20.5s \n", str); //打印 hello /* 输出占m列,但只取字符串中左端n个字符。这n个字符输出在m列的左侧,左补空格。 */ printf("4 = %-20.5s \n", str); //打印 hello /* 如果n>m,则自动取n值,即保证n个字符正常输出。 */ printf("5 = %-5.15s \n", str); //打印 hello world ! /* 自适应打印 */ printf("6 = %.*s \n", strlen(str), str); } int main() { test(); return 0; }
f格式:用来输出实数(包括单--flaot、双精度--double),以小数形式输出,对双精度可以用"%lf"格式输出。有以下几种用法: %f:不指定宽度,整数部分全部输出并输出6位小数。 %m.nf:m为指定的输出字段的宽度,n定义为小数点后保留n位。 m>0时为右对齐,根据n的大小,不足在左边补空格; m<0时为左对齐,根据n的大小,不足在右边补空格; 如果实数本身长度大于m,则突破获m的限制,将实数全部输出。若实数本身长度小于m,则左补空格。 n为小数点后位数,不够补0,多了四舍五入
e格式:以指数形式输出实数。可用以下形式: %e:数字部分(又称尾数)输出6位小数,指数部分占5位或4位。 %m.ne和%-m.ne:m、n和”-”字符含义与前相同。此处n指数据的数字部分的小数位数,m表示整个输出数据所占的宽度。
关于printf函数的进一步说明: 如果想输出字符"%",则应该在“格式控制”字符串中用连续两个%表示,如: printf("%f%%", 1.0/3); //输出0.333333%。