• print输出格式总结


    printf的总结

     1 #include<stdio.h> 
     2 #include<string.h>
     3 #include <iostream>
     4 #include <cmath>
     5 #include <iomanip> 
     6 using namespace std;
     7  
     8 int main() 
     9 { 
    10     char c, s[20]; 
    11     int a=1234;
    12     float f=3.141592653589; 
    13     double x=5.52345678912345678; 
    14     strcpy(s, "Hello,World"); 
    15     c='x41'; 
    16     printf("a=%d
    ", a);//按照十进制整数格式输出,显示 a=1234
    17     printf("a=%d%%
    ", a);//输出%号 结果 a=1234%
    18     printf("a=%6d
    ", a);//输出6位十进制整数 左边补空格,显示 a= 1234
    19     printf("a=%06d
    ", a);//输出6位十进制整数 左边补0,显示 a=001234
    20     printf("a=%2d
    ", a);//a超过2位,按实际输出 a=1234
    21     printf("a=%-6d
    ", a);///输出6位十进制整数 右边补空格,显示 a=1234
    22     printf("f=%f
    ", f);//浮点数有效数字是7位,结果 f=3.141593
    23     printf("f=%6.4f
    ", f);//输出6列,小数点后4位,结果 f=3.1416
    24     printf("new=%0.7f
    ",2.1);//小数后补0,结果2.1000000 
    25     printf("x=%lf
    ", x);//输出长浮点数 x=0.123457
    26     printf("x=%18.16lf
    ", x);//输出18列,小数点后16位,x=0.1234567891234567
    27     printf("c=%c
    ", c);     //输出字符 c=A
    28     printf("c=%x
    ", c);//以十六进制输出字符的ASCII码 c=41
    29     printf("s[]=%s
    ", s);//输出数组字符串s[]=Hello,World
    30     printf("s[]=%6.9s
    ", s);//输出最多9个字符的字符串 s[]=Hello,Wor
    31     printf("x=%.lf
    ",x);    //四舍五入操作 
    32     cout<<"x="<<round(x)<<endl;//四舍五入函数 round() 
    33     cout<<"a="<<setw(3)<<setfill('0')<<28<<endl;
    34     cout<<showpoint<<setprecision(8)<<2.1<<endl;//2.100 0000
    35     // showpoint 和 setiosflags()还是有点区别的,使用时应注意
    36     cout<<setiosflags(ios::fixed) << setprecision(8) <<2.1 <<endl; //2.1000 0000
    37 
    38     return 0;  
    39 }

    编译输出截图如下:

    copy一下别人的总结: 

    格式字符用以指定输出项的数据类型和输出格式。
     ①d格式:用来输出十进制整数。有以下几种用法:
    %d:按整型数据的实际长度输出。
    %md:m为指定的输出字段的宽度。如果数据的位数小于m,则左端补以空格,若大于m,则按实际位数输出。
    %ld:输出长整型数据。
    ②o格式:以无符号八进制形式输出整数。对长整型可以用"%lo"格式输出。同样也可以指定字段宽度用“%mo”格式输出。
    例:
       main()
       { int a = -1;
         printf("%d, %o", a, a);
       }
      运行结果:-1,177777
      程序解析:-1在内存单元中(以补码形式存放)为(1111111111111111)2,转换为八进制数为(177777)8。
    ③x格式:以无符号十六进制形式输出整数。对长整型可以用"%lx"格式输出。同样也可以指定字段宽度用"%mx"格式输出。
    ④u格式:以无符号十进制形式输出整数。对长整型可以用"%lu"格式输出。同样也可以指定字段宽度用“%mu”格式输出。
    ⑤c格式:输出一个字符。
    ⑥s格式:用来输出一个串。有几中用法
    %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个字符正常输出。
    ⑦f格式:用来输出实数(包括单、双精度),以小数形式输出。有以下几种用法:
    %f:不指定宽度,整数部分全部输出并输出6位小数。
    %m.nf:输出共占m列,其中有n位小数,如数值宽度小于m左端补空格。 
    %-m.nf:输出共占n列,其中有n位小数,如数值宽度小于m右端补空格。
    ⑧e格式:以指数形式输出实数。可用以下形式:
    %e:数字部分(又称尾数)输出6位小数,指数部分占5位或4位。
    %m.ne和%-m.ne:m、n和”-”字符含义与前相同。此处n指数据的数字部分的小数位数,m表示整个输出数据所占的宽度。
    ⑨g格式:自动选f格式或e格式中较短的一种输出,且不输出无意义的零。

  • 相关阅读:
    vmware centos 共赏目录不显示
    小程序上拉刷新
    chrome json接口数据 插件
    滚动条滚动事件
    smarty循环item命名规范
    css实现梯形样式(含有border)
    设置行高并不能垂直居中
    图片翻转交互效果
    smarty文章字符截取
    css动画 transition
  • 原文地址:https://www.cnblogs.com/liugl7/p/4896895.html
Copyright © 2020-2023  润新知