在Python3.6.5版本测试通过
它通过{}和:来代替%。
"映射”示例:
1.通过位置
In [1]: '{0},{1}'.format('kzc',18)
Out[1]: 'kzc,18'
In [2]: '{},{}'.format('kzc',18)
Out[2]: 'kzc,18'
In [3]: '{1},{0},{1}'.format('kzc',18)
Out[3]: '18,kzc,18'
In[5]:'{name},{age}'.format(age=18,name='kzc')
Out[5]: 'kzc,18'
或字典方式
In [9]: dic={'name':'ytjoh','age':48}
...: '{name},{age}'.format(**dic)
Out[9]: 'ytjoh,48'
list和tuple可以通过“打散”成普通参数给函数(使用*),而dict可以打散成关键字参数给函数(**)。所以可以轻松的传个list/tuple/dict给format函数。
3.通过对象属性
In [28]: class Person:
...: def __init__(self,name,age):
...: self.name,self.age = name,age
...: def __str__(self):
...: return 'This guy is {self.name},is {self.age} old'.format(self=self)
In [29]: str(Person('ytjoh',48))
Out[29]: 'This guy is ytjoh,is 48 old'
4.通过下标
In [30]: p=['ytjoh',48]
...: '{0[0]},{0[1]}'.format(p)
Out[30]: 'ytjoh,48'
In [40]: dic={'name':'ytjoh','age':48}
...: '{d[name]},{d[age]}'.format(d=dic)
Out[40]: 'ytjoh,48'
5.用%s和%r替换
In [35]: "repr() shows quotes: {!r}; str() doesn't: {!s}".format('test1', 'test2')
Out[35]: "repr() shows quotes: 'test1'; str() doesn't: test2"
格式限定符(format_spec)
它有着丰富的的“格式限定符”(语法是{}中带:号),比如:
填充与对齐
填充常跟对齐一起使用
^、<、>分别是居中、左对齐、右对齐,后面带宽度
:号后面带填充的字符,只能是一个字符,不指定的话默认是用空格填充
比如
In [31]: '{:>8}'.format('ytjoh')
Out[31]: ' ytjoh'
在这里,我们重点看一下格式描述(format_spec)这一项。
格式描述中含有6个选项,分别是 fill、align、sign、width、precision、type。 它们的位置关系如下:
[[fill]align][sign][#][0][width][,][.precision][type] fill 可以是任意字符,默认为空格。
align 仅当指定最小宽度时有效。
< 左对齐(默认选项) > 右对齐 = 仅对数字有效;将填充字符放到符号与数字间,例如 +0001234 ^ 居中对齐
sign 仅对数字有效
+ 所有数字均带有符号 - 仅负数带有符号(默认选项) 即空格;正数前面带空格,负数前面带符号
'#' 只对整数有效
自动在二进制、八进制、十六进制数值前添加对应的 0b、0o、 0x。
',' 自动在每三个数字之间添加 , 分隔符。
width 十进制数字,定义最小宽度。如果未指定,则由内容的宽度来决定。
如果没有指定对齐方式(align),那么可以在 width 前面添加一个0来实现自动填充0,等价于 fill 设为 0 并且 align 设为 =。
precision 用于确定浮点数的精度,或字符串的最大长度。不可用于整型数值。
type 确定参数类型,默认为 s ,即字符串。
整数输出类型:
b:以二进制格式输出 c:将整数转换成对应的 unicode 字符 d:以十进制输出(默认选项) o:以八进制输出 x:以十六进制小写输出 X:以十六进制大写输出 n:与 d 相同,但使用当前环境的分隔符来分隔每3位数字
十进制浮点数输出类型:
e:指数标记;使用科学计数法输出,用e来表示指数部分,默认 precision 为6 E:与 e 相同,但使用大写 E 来表示指数部分 f:以定点形式输出数值,默认 precision 为6 F:与 f 相同 g:通用格式;对于给定的 precision p >= 1,取数值的p位有效数字,并以定点或科学计数法输出(默认选项) G:通用格式;与 g 相同,当数值过大时使用 E 来表示指数部分 n:与 g 相同,但使用当前环境的分隔符来分隔每3位数字 %:百分比标记;使用百分比的形式输出数值,同时设定 f 标记
相关函数:format : 内置函数
用法:format(value[, format_spec])
本函数把值value按format_spec的格式来格式化,然而函数解释format_spec是根据value的类型来决定的,不同的类型有不同的格式化解释。当参数format_spec为空时,本函数等同于函数str(value)的方式。
其实本函数调用时,是把format(value, format_spec)的方式转换为type(value).__format__(format_spec)方式来调用,因此在value类型里就查找方法__format__(),如果找不到此方法,就会返回异常TypeError
In [36]: print('aaaa'.__format__('?>20'))
????????????????aaaa
In [36]:
In [37]: format('aaaa','?>20')
Out[37]: '????????????????aaaa'