• printf/scanf格式修饰符


    格式转换说明符printf() / scanf()

     

    表一 转换说明符及作为结果的打印输出

    转换说明

     

    %a

    浮点数、十六进制数字和p-记数法 (C99)

    %A

    浮点数、十六进制数字和P-记数法 (C99)

    %c

    一个字符

    %d

    有符号十进制整数

    %e

    浮点数、e-记数法

    %E

    浮点数、E-记数法

    %f

    浮点数,十进制记数法

    %g

    根据数值不同自动选择%f或者%e%e格式在指数小于-4或者大于等于精度时使用

    %G

    根据数值不同自动选择%f或者%E%E格式在指数小于-4或者大于等于精度时使用

    %i

    有符号十进制整数 (%d相同)

    %o

    无符号八进制整数

    %p

    指针(就是指地址)

    %s

    字符串

    %u

    无符号十进制整数

    %x

    使用十六进制数字0f 无符号十六进制整数

    %X

    使用十六进制数字0F无符号十六进制整数

    %%

    打印一个百分号

     

    表二 printf() 修饰符

    修饰符

     

    标志

    五种标志 (-+、空格、# 0) 都将在表三中描述,可以使用零个或多个标志

    digit(s)

    字段宽度的最小值。如果该字段不能容纳要打印的数或者字符串,系统会使用更宽的字段。示例:“M”

    .digit(s)

    精度。对于%e%E%f转换,是将要在小数点的右边打印的数字的位数。对于%g%G转换,是有效数字的最大位数。对于%s转换,是将要打印的字符的最大数目。对于整数转换,是将要打印的数字的最小位数;如果必要,要使用前导零来达到这个位数。只使用“.”表示其后跟随一个零,所以%.f%.0f相同。示例:“%5.2f”打印一个浮点数,他的字段宽度为5个字符,小数点后有两个数字。

    h

    和整数转换说明符一起使用,表示一个short int 或者 unsigned short int 类型数值。

    示例:“%hu”“%hx”“%6.4hd”

    hh

    和整数转换说明符一起使用,表示一个signed char 或者unsigned char类型数值。

    示例:“%hhu”“%hhx”“%6.4hhd”

    j

    和整数转换说明符一起使用,表示一个intmax_tuintmax_t值。

    示例:“%jd”“%8jX”

    l

    和整数说明符一起使用,表示一个long int 或者unsigned long int 类型值。

    示例:“%ld”“%8lu”

    ll

    和整数说明符一起使用,表示一个long long int unsigned long long int 类型值 (C99)

    示例:“%lld”“%8llu”

    L

    和浮点转换说明符一起使用,表示一个long double值。

    示例:“%Lf”“.4Le”

    t

    和整数转换说明符一起使用,表示一个ptrdiff_t(与两个指针之间的差相对应的类型) (C99)

    示例:“%td”“ti”

    z

    和整数转换说明符一起使用表示一个size_t(sizeof返回的类型) (C99)

    示例%zd”zx”

     

    表三 printf()的标志

    修饰符

     

    -

    项目是左对齐的,也就是说,会把项目打印在字段的左侧开始处。示例:%-20s

    +

    有符号的值若为正,则显示带加号的符号;若为负,则带减号的符号。示例:%+6.2f

    (空格)

    有符号的值若为正,则显示时带前导空格(但是不显示符号);若为负,则带减号符号。+标志会覆盖空格标志。示例:% 6.2f

    #

    使用转换说明的可选形式。若为%o格式,则以0开始;若为%x%X格式,则以0x0X开始,对于所有的浮点形式,#保证了即使不限任何数字,也打印一个小数点字符。对于%g%G格式,它防止尾随零被删除。示例:%#o%#8.0f%+#10.3E

    0

    对于所有的数字格式,用前导零而不是用空格填充字段宽度。如果出现-标志或者指定了精度(对于整数)则忽略该标志。示例:0d.3f

     

    表四 ANSIC  scanf()的转换说明符

    转换说明符

     

    %c

    把输入解释成一个字符

    %d

    把输入解释成一个有符号十进制整数

    %e%f%g %a

    把输入解释成一个浮点数 (%aC99标准)

    %E%F%G%A

    把输入解释成一个浮点数 (%AC99标准)

    %i

    把输入解释成一个有符号十进制整数

    %o

    把输入解释成一个有符号八进制数

    %p

    把输入解释成一个指针(地址)

    %s

    把输入解释成一个字符串;输入的内容以一个非空白字符作为开始,并且包含知道下一个空白字符的全部字符

    %u

    把输入解释成一个无符号十进制整数

    %x%X

    把输入解释成一个有符号十六进制整数

     

    表五 scanf()的转换修饰符

    修饰符

     

    *

    滞后赋值。示例:%*d

    digit(s)

    最大字段宽度;在达到最大字段宽度或者遇到第一个空白字符时(不管哪一个先发生都一样)停止对输入项的读取。示例:s

    hh

    把整数读作signed char  unsigned char 。示例:%hhd”“%hhu

    ll

    把整数读作long long或者 unsigned long long (C99)。示例:%lld”“%llu

    hlL

    %hdhi指示该值将会存储在一个short int中。

    %ho”“%hx%hu指示该值将会存储在一个unsigned short int中。

    %ld%li指示该值将会存储在一个long中。

    %lo”“%lx%lu指示该值将会存储在一个unsigned long中。

    %le”“%lf%lg指示该值以double类型存储。将L(而非l)efg一起使用指示该值以long double类型存储。

    如果没有这些修饰符,diox指示int类型,而efg指示float类型。

     

  • 相关阅读:
    DB2 db2move导入导出数据及使用dblook导出表结构DDL
    【转】DB2 BLOB大字段数据通过命令行进行导入导出
    【转】【DataGuard】Oracle 11g物理Data Guard之Snapshot Standby数据库功能
    【转】Oracle 11g R2手动配置EM
    【转】Oracle Database Server 'TNS Listener'远程数据投毒漏洞(CVE-2012-1675)
    【转】ORACLE TNS Listener远程注册投毒(Poison Attack)漏洞
    【转】Oracle 11.2.0.4/12C新特性Valid Node Checking For Registration (VNCR)
    【转】使用 xtrabackup 进行MySQL数据库物理备份
    【转】MySQL-物理备份-Percona XtraBackup 备份原理
    【转】NBU expired Media,Media ID not found in EMM database
  • 原文地址:https://www.cnblogs.com/fengfengqingqingyangyang/p/2789320.html
Copyright © 2020-2023  润新知