zoukankan      html  css  js  c++  java
  • Python字符串格式化%s%d%f详解

    %s 字符串

    string="hello"  
      
    #%s打印时结果是hello  
    print "string=%s" % string   # output: string=hello  
      
    #%2s意思是字符串长度为2,当原字符串的长度超过2时,按原长度打印,所以%2s的打印结果还是hello  
    print "string=%2s" % string   # output: string=hello  
      
    #%7s意思是字符串长度为7,当原字符串的长度小于7时,在原字符串左侧补空格,  
    #所以%7s的打印结果是 hello  
    print "string=%7s" % string   # output: string= hello  
      
    #%-7s意思是字符串长度为7,当原字符串的长度小于7时,在原字符串右侧补空格,  
    #所以%-7s的打印结果是 hello  
    print "string=%-7s!" % string   # output: string=hello !  
      
    #%.2s意思是截取字符串的前2个字符,所以%.2s的打印结果是he  
    print "string=%.2s" % string  # output: string=he  
      
    #%.7s意思是截取字符串的前7个字符,当原字符串长度小于7时,即是字符串本身,  
    #所以%.7s的打印结果是hello  
    print "string=%.7s" % string  # output: string=hello  
      
    #%a.bs这种格式是上面两种格式的综合,首先根据小数点后面的数b截取字符串,  
    #当截取的字符串长度小于a时,还需要在其左侧补空格  
    print "string=%7.2s" % string  # output: string=   he  
    print "string=%2.7s" % string  # output: string=hello  
    print "string=%10.7s" % string # output: string=   hello  
      
    #还可以用%*.*s来表示精度,两个*的值分别在后面小括号的前两位数值指定  
    print "string=%*.*s" % (7,2,string)   # output: string=   he  

    %d整形

    num=14  
      
    #%d打印时结果是14  
    print "num=%d" % num      # output: num=14  
      
    #%1d意思是打印结果为1位整数,当整数的位数超过1位时,按整数原值打印,所以%1d的打印结果还是14  
    print "num=%1d" % num      # output: num=14  
      
    #%3d意思是打印结果为3位整数,当整数的位数不够3位时,在整数左侧补空格,所以%3d的打印结果是 14  
    print "num=%3d" % num      # output: num= 14  
      
    #%-3d意思是打印结果为3位整数,当整数的位数不够3位时,在整数右侧补空格,所以%3d的打印结果是14_  
    print "num=%-3d" % num     # output: num=14_  
      
    #%05d意思是打印结果为5位整数,当整数的位数不够5位时,在整数左侧补0,所以%05d的打印结果是00014  
    print "num=%05d" % num     # output: num=00014  
      
    #%.3d小数点后面的3意思是打印结果为3位整数,  
    #当整数的位数不够3位时,在整数左侧补0,所以%.3d的打印结果是014  
    print "num=%.3d" % num     # output: num=014  
      
    #%.0003d小数点后面的0003和3一样,都表示3,意思是打印结果为3位整数,  
    #当整数的位数不够3位时,在整数左侧补0,所以%.3d的打印结果还是014  
    print "num=%.0003d" % num    # output: num=014  
      
    #%5.3d是两种补齐方式的综合,当整数的位数不够3时,先在左侧补0,还是不够5位时,再在左侧补空格,  
    #规则就是补0优先,最终的长度选数值较大的那个,所以%5.3d的打印结果还是 014  
    print "num=%5.3d" % num     # output: num= 014  
      
    #%05.3d是两种补齐方式的综合,当整数的位数不够3时,先在左侧补0,还是不够5位时,  
    #由于是05,再在左侧补0,最终的长度选数值较大的那个,所以%05.3d的打印结果还是00014  
    print "num=%05.3d" % num    # output: num=00014  
      
    #还可以用%*.*d来表示精度,两个*的值分别在后面小括号的前两位数值指定  
    #如下,不过这种方式04就失去补0的功能,只能补空格,只有小数点后面的3才能补0  
    print "num=%*.*d" % (04,3,num) # output: num= 014  

    %f浮点型

    import math  
      
    #%a.bf,a表示浮点数的打印长度,b表示浮点数小数点后面的精度  
      
    #只是%f时表示原值,默认是小数点后5位数  
    print "PI=%f" % math.pi       # output: PI=3.141593  
      
    #只是%9f时,表示打印长度9位数,小数点也占一位,不够左侧补空格  
    print "PI=%9f" % math.pi      # output: PI=_3.141593  
      
    #只有.没有后面的数字时,表示去掉小数输出整数,03表示不够3位数左侧补0  
    print "PI=%03.f" % math.pi     # output: PI=003  
      
    #%6.3f表示小数点后面精确到3位,总长度6位数,包括小数点,不够左侧补空格  
    print "PI=%6.3f" % math.pi     # output: PI=_3.142  
      
    #%-6.3f表示小数点后面精确到3位,总长度6位数,包括小数点,不够右侧补空格  
    print "PI=%-6.3f" % math.pi     # output: PI=3.142_  
      
    #还可以用%*.*f来表示精度,两个*的值分别在后面小括号的前两位数值指定  
    #如下,不过这种方式06就失去补0的功能,只能补空格  
    print "PI=%*.*f" % (06,3,math.pi)  # output: PI=_3.142  
  • 相关阅读:
    HashCode和equal方法的区别和联系 [转]
    Linux makefile 教程 [转]
    gcc: multiple definition of [转]
    conda虚拟环默认路径
    terrasolid修改背景颜色
    台式机无法开机可能的原因
    TensorFlow2.1中计算平方函数的tf.square()的用法
    Terrasolid 安装教程
    如何解决Pytorch的GPU driver is too old的问题?
    使用 TensorBoard 可视化进行监督
  • 原文地址:https://www.cnblogs.com/yyxianren/p/15529329.html
Copyright © 2011-2022 走看看