字符串的输出格式可以由下面的语法进行控制:
%[(name)][flag][width][.][precision]type
这套格式化字符串的方法被很多编程语言沿用,包括c
,cpp
,java
,python
等,所以,我们明白了这一套的话,在别的语言里同样也可以用,所以学一下这套语法还是很有用处的.
上面被[]
括住的项表示该项是可选的.
其中,(name)
表示命名,这个其实用得不多.这也是python
对这套语法的扩展,别的语言里没有这一套.这里仅仅举一个栗子,说明一下,即使没有这一项,也没有多大的影响,这一项可以通过别的格式化操作实现,所以这玩意只是一个语法糖而已,觉得麻烦的话,丢掉就好了:
print("I'm %(name)s. I'm %(age)d year old" % {'name':'Vamei', 'age':99})
结果如下:
I'm Vamei. I'm 99 year old
flag
为标记格式限定符号,包含+``-``#
和0
,+
表示右对齐(会显示正负号),-
表示左对齐,前面默认为填充空格(即默认右对齐),0
表示填充0
,#
表示八进制时前面补充0
,16
进制数填充0x
,二进制填充0b
.
width
用于表示宽度或者说最短长度,一个字符占据一个宽度,包含小数点,当要输出的内容对应的字符数小于width
时会按照前面flag
的指示来进行填充,如果flag
为空,那么用空格填充.
precision
一般只对小数有效,控制输出在小数点之后的位数.
type
表示类型码,具体如下表所示:
类型码 | 说明 |
---|---|
%s |
字符串 (采用str() 的显示) |
%r |
字符串 (采用repr() 的显示) |
%c |
单个字符 |
%b |
二进制整数 |
%d | 有符号十进制整数 |
%i |
有符号十进制整数 |
%o | 无符号八进制整数 |
** %x ** | 输出使用小写字母a~f,表示无符号十六进制整数 |
%X | 输出使用大写字母A~F,表示无符号十六进制整数 |
%e |
指数 (基底写为e ) |
%E |
指数 (基底写为E ) |
%f |
浮点数 |
%F |
浮点数,与上相同 |
%g |
指数(e )或浮点数 (根据显示长度) |
%G |
指数(E )或浮点数 (根据显示长度) |
%u | 无符号十进制整数 |
这套语法其实是一个非常小的DSL
,很有意思,有兴趣的同学可以练习一下,自上而下分析设定,做一个小型的parser
.
补充
一些不常用,但是很有用的东西.
类型码 | 说明 |
---|---|
hh | 和整数类型码一起使用,表示一个signed char或者unsigned char(8bit),常用有%hhx表示用16进制输出一个1字节的unsigned char类型 |
ll | 和整数类型码一起使用,表示一个long long int或者unsigned long long int类型,比如%llx表示用16进制输出一个4字节的unsigned long long int类型 |