printf使用

    技术2022-05-19  29

    From: http://hi.baidu.com/agodliness/blog/item/344a93f47eb15a6dddc474de.html 格式代码 A ABC ABCDEFGH %S A ABC ABCDEFGH %5S ####A ##ABC ABCDEFGH %.5S A ABC ABCDE %5.5S ####A ##ABC ABCDE %-5S A#### ABC## ABCDEFGH Printf 格式化字符串 格式代码 1 -12 12345 123456789 %d 1 -12 12345 123456789 %6d #####1 ###-12 #12345 123456789 %.4d 0001 -0012 12345 123456789 %6.4d ##0001 #-0012 #12345 123456789 %-4d 1#### -12# 12345 123456789 d 0001 -012 12345 123456789 %+d +1 -12 +12345 +123456789 Printf格式化整型数值 格式代码 1 .01 .00012345 12345.6789 %f 1.000000 0.010000 0.000123 12345.678900 .2d ######1.00 #####0.01 ######0.00 ##12345.67 %e 1.000000e+00 1.000000e-02 1.234500e-04 1.234568e+04 %.4e 1.0000e+00 1.0000e-02 1.2345e-04 1.2346e+04 %g 1 0.01 0.00012345 12345.7 格式代码 6.023e23 %f 60229999999999975882752.000000 .2e 60229999999999975882752.00 %e 6.023000e+23 %.4e 6.0230e+23 %g 6.023e+23 Printf格式化浮点值

    printf()格式转换的一般形式如下%(flags)(width)(.prec)type以中括号括起来的参数为选择性参数,而%与type则是必要的。底下先介绍type的几种形式

    整数%d 整数的参数会被转成一有符号的十进制数字%u 整数的参数会被转成一无符号的十进制数字%o 整数的参数会被转成一无符号的八进制数字%x 整数的参数会被转成一无符号的十六进制数字,并以小写abcdef表示%X 整数的参数会被转成一无符号的十六进制数字,并以大写ABCDEF表示浮点型数

    %f double 型的参数会被转成十进制数字,并取到小数点以下六位,四舍五入。%e double型的参数以指数形式打印,有一个数字会在小数点前,六位数字在小数点后,而在指数部分会以小写的e来表示。%E 与%e作用相同,唯一区别是指数部分将以大写的E 来表示。%g double 型的参数会自动选择以%f 或%e 的格式来打印,其标准是根据欲打印的数值及所设置的有效位数来决定。%G 与%g 作用相同,唯一区别在以指数形态打印时会选择%E 格式。

    字符及字符串%c 整型数的参数会被转成unsigned char型打印出。%s 指向字符串的参数会被逐字输出,直到出现NULL字符为止%p 如果是参数是“void *”型指针则使用十六进制格式显示。

    prec 有几种情况1. 正整数的最小位数。2. 在浮点型数中代表小数位数3. 在%g 格式代表有效位数的最大值。4. 在%s格式代表字符串的最大长度。5. 若为×符号则代表下个参数值为最大长度。

    width为参数的最小长度,若此栏并非数值,而是*符号,则表示以下一个参数当做参数长度。

    flags 有下列几种情况#NAME?+ 一般在打印负数时,printf()会加印一个负号,整数则不加任何负号。此旗标会使得在打印正数前多一个正号(+)。# 此旗标会根据其后转换字符的不同而有不同含义。当在类型为o 之前(如%#o),则会在打印八进制数值前多印一个o。而在类型为x 之前(%#x)则会在打印十六进制数前多印’0x’,在型态为e、E、f、g或G 之前则会强迫数值打印小数点。在类型为g 或G之前时则同时保留小数点及小数位数末尾的零。0 当有指定参数时,无数字的参数将补上0。默认是关闭此旗标,所以一般会打印出空白字符


    最新回复(0)