python格式化字符串
2017-04-23 本文已影响47人
Yihulee
字符串的输出格式可以由下面的语法进行控制:
%[(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类型 |