python str.format知识点备忘

2021-07-08 20:05

阅读:634

语法 str.format(*args, **kwargs)

它通过{}和:来代替%。

"映射”示例:

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

2.通过关键字参数

 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详解

在这里,我们重点看一下格式描述(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])

本函数把值valueformat_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

 

 

 


评论


亲,登录后才可以留言!