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%。

 

posted on 2018-01-14 10:05  寒魔影  阅读(17958)  评论(0编辑  收藏  举报

导航