• 格式化字符串两种方式


    Python中内置有对字符串进行格式化的操作 %和使用format函数。

    %方式操作

    格式化字符串时,Python使用一个字符串作为模板。模板中有格式符,这些格式符为真实值预留位置,并说明真实数值应该呈现的格式。Python用一个tuple将多个值传递给模板,每个值对应一个格式符。

    比如下面的例子:

      1 print("I'm %s. I'm %d year old" % ('韩梅梅', 20))
      2 a = "I'm %s. I'm %d year old" % ('韩梅梅', 99) #构成一个字符串表达式
      3 print(a) 

    执行结果:

    I'm 韩梅梅. I'm 20 year old
    I'm 韩梅梅. I'm 99 year old

    上面的例子中,

    "I'm %s. I'm %d year old" 为我们的模板。%s为第一个格式符,表示一个字符串。%d为第二个格式符,表示一个整数。('Vamei', 99)的两个元素'Vamei'和99为替换%s和%d的真实值。
    在模板和tuple之间,有一个%号分隔,它代表了格式化操作。

    还可以用词典来传递真实值。如下:

    print("I'm %(name)s. I'm %(age)d year old" % {'name': '韩梅梅' , 'age':99})

    可以看到,我们对两个格式符进行了命名。命名使用()括起来。每个命名对应词典的一个key。

    格式符

    格式符为真实值预留位置,并控制显示的格式。格式符可以包含有一个类型码,用以控制显示的类型,如下:

    %s    字符串 (采用str()的显示)

    %r    字符串 (采用repr()的显示)

    %c    单个字符

    %b    二进制整数

    %d    十进制整数

    %i    十进制整数

    %o    八进制整数

    %x    十六进制整数

    %e    指数 (基底写为e)

    %E    指数 (基底写为E)

    %f    浮点数

    %F    浮点数,与上相同

    %g    指数(e)或浮点数 (根据显示长度)

    %G    指数(E)或浮点数 (根据显示长度)

    %%    字符"%"

    可以用如下的方式,对格式进行进一步的控制:

    %[(name)][flags][width].[precision]typecode

    (name)为命名

    flags可以有+,-,' '或0。+表示右对齐。-表示左对齐。' '为一个空格,表示在正数的左侧填充一个空格,从而与负数对齐。0表示使用0填充。

    width表示显示宽度

    precision表示小数点后精度:

    print("%+10x" % 10)
    print("%04d" % 5)
    print("%6.3f" % 2.3)
    
    执行结果
             +a
    0005
    2.300
    

    上面的width, precision为两个整数。我们可以利用*,来动态代入这两个量。比如:

    print("%.*f" % (4, 1.2))  #1.2000

    Python实际上用4来替换*。所以实际的模板为"%.4f"。


    str.formar()

    语法:它通过{}和:来代替%。“映射”示例

    通过位置

    >>> "{0},{1}".format('韩梅梅',20)
    '韩梅梅,20'
    >>> "{},{}".format('韩梅梅',20)
    '韩梅梅,20'
    >>> "{0},{1},{0}".format('韩梅梅',20)
    '韩梅梅,20,韩梅梅'
    

    通过关键字参数

    >>>"{name},{age}".format(name='韩梅梅',age=20)
    '韩梅梅,20'
    

    通过对象属性

      1 class Person:
      2     def __init__(self,name,age):
      3         self.name,self.age = name,age
      4     def __str__(self):
      5         return 'This guy is {self.name},is {self.age} old'.format(self=self)
      6 
      7 str(Person('韩梅梅',20))

    执行结果:

    'This guy is 韩梅梅,is 20 old'

    通过下标

    >>> list1 = ['韩梅梅',20]
    >>> '{0[0]},{0[1]}'.format(list1)
    '韩梅梅,20'
    

    格式限定符

    它有着丰富的的“格式限定符”(语法是{}中带:号),比如:

    填充与对齐
    填充常跟对齐一起使用
    ^、<、>分别是居中、左对齐、右对齐,后面带宽度
    :号后面带填充的字符,只能是一个字符,不指定的话默认是用空格填充
    比如

    >>> '{:>8}'.format('home')
    ' home'
    >>> '{:0>8}'.format('home')
    '0000home'
    >>> '{:*>8}'.format('home')
    '****home'
    

    精度与类型f
    精度常跟类型f一起使用

    >>> '{:.2f}'.format(3.1415926)
    '3.14'
    

    其中.2表示长度为2的精度,f表示float类型。

    其他类型
    主要就是进制了,b、d、o、x分别是二进制、十进制、八进制、十六进制。

    >>> '{:b}'.format(10)
    '1010'
    >>> '{:d}'.format(10)
    '10'
    >>> '{:o}'.format(10)
    '12'
    >>> '{:x}'.format(10)
    'a'
    

    用’,’号还能用来做金额的千位分隔符。

    >>> '{:,}'.format(1234567890)
    '1,234,567,890'
    
  • 相关阅读:
    国外可用的谷歌地图(可根据地址搜索经纬度)
    后台css框架(自用)
    DBHelp类sql分页(自用笔记)
    定制C++高效安全的运行时动态类型转换
    C++11右值引用和std::move语句实例解析
    浏览器内核-Webkit
    获取股票历史数据和当前数据的API
    从浏览器启动应用程序
    一个实时获取股票数据的安卓应用程序
    C++数据类型总结
  • 原文地址:https://www.cnblogs.com/pinpin/p/9982582.html
Copyright © 2020-2023  润新知