printf输出各种格式(转)

    技术2025-03-01  36

    printf 输出格式

    (一)使用printf输出各种格式的字符串

    1. 原样输出字符串:    printf(“%s”, str);

    2. 输出指定长度的字符串, 超长时不截断, 不足时右对齐:    printf(“%Ns”, str);             –N 为指定长度的10进制数值

    3. 输出指定长度的字符串, 超长时不截断, 不足时左对齐:    printf(“%-Ns”, str);            –N 为指定长度的10进制数值

    4. 输出指定长度的字符串, 超长时截断, 不足时右对齐:    printf(“%N.Ms”, str);           –N 为最终的字符串输出长度                                    –M 为从参数字符串中取出的子串长度

    5. 输出指定长度的字符串, 超长时截断, 不足时左对齐是:    printf(“%-N.Ms”, str);          –N 为最终的字符串输出长度                                    –M 为从参数字符串中取出的子串长度

     ★d格式符,用来输出十进制整数.

                    ⑴%d,按整型数据的实际长度输出.

                    ⑵%md,m为指定的输出字段的宽度,数据位数小于m,左边补空格,若大于m,按实际长度输出

                    ⑶%ld,输出长整型数据(long)

     ★o格式符,以八进制输出整数(不带符号,他将符号位也作为八进制数的一部分了)                ⑴%o,参考%d的解释.

                    ⑵%lo,参考%ld的解释.

                    ⑶%mo,参考%md的解释.

     ★x,X格式符,以十六进制输出整数                也是3种参考%d的解释. ★u格式符,用来将unsigned型数据,既无符号数,以十进制形式输出 ★c格式符,输出一个字符. ★s格式符,输出一个字符串.                ⑴%s,如printf(“%s”,”CHINA”)

                    ⑵%ms,输出的字符串占m列,字符串长度小于m,左边补空格,如果超出则全部输出.

                    ⑶%-ms,串小于m,则在m列范围内字符串左靠,右补空格.

                    ⑷%m.ns,输出占m列,但只取字符串左端n个字符.这n个字符输出在m列的右边,然后左边补空格.

                    ⑸%-m.ns,和上面的放下,就是n个字符输出在m列的左侧,右边补空格.n>m,那么m自动取n的值,既保证n个字符正常输出.

                    printf(“%3s,%7.2s,%.4s,%-5.3s“,”CHINA”,”CHINA”,”CHINA”,”CHINA”);

     ★f格式符,用来输出实数,以小数形式输出.

                    ⑴%f,全部输出,而且输出6位小数.

                    ⑵%m.nf,输出数据共占m列,n位小数,如果数据长度小于m那么左边补空格

                    ⑶%-m.nf,和上面的m.nf相反,为左靠齐,右补空格.

     ★e,E格式符,以指数形式输出实数

                    ⑴%e,不指定输出数据所占的宽度和数字部分的小数位数.

                    ⑵%m.ne和%-m.ne,这里n指小数部分的位数

     ★g,G格式符,用来输出实数,它根据数值大小,自动选择f格式还是e格式,(选占宽最少的一种),且不输出无意义的0.这种格式用的不多.

     

     

     

     

     

     

     

     

    文章分类:综合技术

     printf()函数是格式化输出函数, 一般用于向标准输出设备按规定格式输出   信息。在编写程序时经常会用到此函数。函数的原型为:   int printf(const char *format, ...);   函数返回值为整型。若成功则返回输出的字符数,输出出错则返回负值。   printf()函数的调用格式为:   printf("<格式化字符串>", <参量表>);   其中格式化字符串包括两部分内容: 一部分是正常字符, 这些字符将按原   样输出; 另一部分是格式化规定字符, 以"%"开始, 后跟一个或几个规定字符,   用来确定输出内容格式。   参量表是需要输出的一系列参数, 其个数必须与格式化字符串所说明的输出   参数个数一样多, 各参数之间用","分开, 且顺序一一对应, 否则将会出现意想   不到的错误。   注意:函数printf从左往右读取,然后将先读取放到栈底,最后读取的放在栈顶,处理时候是从栈顶开始的,所有我们看见的结果是,从右边开始处理的。   1. 格式化规定符   Turbo C2.0提供的格式化规定符如下:   ━━━━━━━━━━━━━━━━━━━━━━━━━━

    a 符号 作用   ——————————————————————————   %d 十进制有符号整数   %u 十进制无符号整数   %f 浮点数   %s 字符串   %c 单个字符   %p 指针的值   %e 指数形式的浮点数   %x, %X 无符号以十六进制表示的整数   %o 无符号以八进制表示的整数   %g 自动选择合适的表示法   ━━━━━━━━━━━━━━━━━━━━━━━━━━   说明:   (1). 可以在"%"和字母之间插进数字表示最大场宽。   例如: %3d 表示输出3位整型数, 不够3位右对齐。   %9.2f 表示输出场宽为9的浮点数, 其中小数位为2, 整数位为6,   小数点占一位, 不够9位右对齐。   %8s 表示输出8个字符的字符串, 不够8个字符右对齐。   如果字符串的长度、或整型数位数超过说明的场宽, 将按其实际长度输出。   但对浮点数, 若整数部分位数超过了说明的整数位宽度, 将按实际整数位输出;   若小数部分位数超过了说明的小数位宽度, 则按说明的宽度以四舍五入输出。   另外, 若想在输出值前加一些0, 就应在场宽项前加个0。   例如: %04d 表示在输出一个小于4位的数值时, 将在前面补0使其总宽度   为4位。   如果用浮点数表示字符或整型量的输出格式, 小数点后的数字代表最大宽度,   小数点前的数字代表最小宽度。   例如: %6.9s 表示显示一个长度不小于6且不大于9的字符串。若大于9, 则   第9个字符以后的内容将被删除。   (2). 可以在"%"和字母之间加小写字母l, 表示输出的是长型数。   例如: %ld 表示输出long整数   %lf 表示输出double浮点数   (3). 可以控制输出左对齐或右对齐, 即在"%"和字母之间加入一个"-" 号可   说明输出为左对齐, 否则为右对齐。   例如: %-7d 表示输出7位整数左对齐   %-10s 表示输出10个字符左对齐   2. 一些特殊规定字符   ━━━━━━━━━━━━━━━━━━━━━━━━━━

    b 字符 作用   ——————————————————————————   /n 换行   /f 清屏并换页   /r 回车   /t Tab符   /xhh 表示一个ASCII码用16进表示,   其中hh是1到2个16进制数   ━━━━━━━━━━━━━━━━━━━━━━━━━━   由本节所学的printf()函数, 并结合上一节学习的数据类型, 编制下面的程   序, 以加深对Turbo C2.0数据类型的了解。

    示例   #include<stdio.h>   #include<string.h>   int main()   {   char c, s[20], *p;   int a=1234, *i;   float f=3.141592653589;   double x=0.12345678987654321;   p="How do you do";   strcpy(s, "Hello, Comrade");   *i=12;   c='/x41';   printf("a=%d/n", a); /*结果输出十进制整数a=1234*/   printf("a=%6d/n", a); /*结果输出6位十进制数a= 1234*/   printf("a=%06d/n", a); /*结果输出6位十进制数a=001234*/   printf("a=%2d/n", a); /*a超过2位, 按实际值输出a=1234*/   printf("*i=%4d/n", *i); /*输出4位十进制整数*i= 12*/   printf("*i=%-4d/n", *i); /*输出左对齐4位十进制整数*i=12*/   printf("i=%p/n", i); /*输出地址i=06E4*/   printf("f=%f/n", f); /*输出浮点数f=3.141593*/   printf("f=6.4f/n", f); /*输出6位其中小数点后4位的浮点数   f=3.1416*/   printf("x=%lf/n", x); /*输出长浮点数x=0.123457*/   printf("x=%18.16lf/n", x);/*输出18位其中小数点后16位的长浮点   数x=0.1234567898765432*/   printf("c=%c/n", c); /*输出字符c=A*/   printf("c=%x/n", c); /*输出字符的ASCII码值c=41*/   printf("s[]=%s/n", s); /*输出数组字符串s[]=Hello, Comrade*/   printf("s[]=%6.9s/n", s);/*输出最多9个字符的字符串s[]=Hello,   Co*/   printf("s=%p/n", s); /*输出数组字符串首字符地址s=FFBE*/   printf("*p=%s/n", p); /* 输出指针字符串p=How do you do*/   printf("p=%p/n", p); /*输出指针的值p=0194*/   getch();   retunr 0;   }   上面结果中的地址值在不同计算机上可能不同。   例.中第一条语句#include<stdio.h>的含义是调用另一个文件stdio.h, 这   是一个头文件, 其中包括全部标准输入输出库函数的数据类型定义和函数说明。   Turbo C2.0对每个库函数便用的变量及函数类型都已作了定义与说明, 放在相应   头文件"*.h"中, 用户用到这些函数时必须要用#include<*.h>或#include"*. h"   语句调用相应的头文件, 以供连接。若没有用此语句说明, 则连接时将会出现错   误。   printf()和sprintf()在php中的应用   <?php   printf("$%01.2f", 43.2); // 运行结果:$43.20   echo "   ";   printf("%d bottles of beer on %s", 100, "the wall");   echo "   ";   //运行结果:100 bottles of beer on the wall   printf("%15s", "some text"); //运行结果:some text   ?>   <?php   echo "   ";   printf("The %2/$s likes to %1/$s", 111, dog);   echo "   ";   //运行结果: The dog likes to bark   printf("The %1/$s says: %2/$s, %2/$s.", "dog", "bark");   //运行结果:The dog says: bark, bark.   ?>   <?php   echo "   ";   $var1 = 68.75;   $var2 = 54.35;   $var3 = $var1 + $var2;   echo $var3;   echo "   ";   // 变量 $var3 值为 "123.1";   $formatted = sprintf ("%01.2f", $var3);   echo "   ";   echo $formatted;   // 变量$var3 值为 "123.10"   ?>   <?php   echo "   ";   $money = 1.4;   $formatted = sprintf ("%-01.2f", $money);   echo $formatted;   ?>   结果:   $43.20   100 bottles of beer on the wall   some text   The dog likes to 111   The dog says: bark, bark.   123.1   123.10   1.40

    最新回复(0)