python字符串格式化输出 %和format举例

#!/usr/bin/env python
# -*- coding: UTF-8 -*-
#pyversion:python3.5
#owner:fuzj


s1 = "i am %s, i am %d years old" % ('jeck',26)    #按位置顺序依次输出
s2 = "i am %(name)s, i am %(age)d years old" % {'name':'jeck','age':26}   #自定义key输出
s3 = "i am %(name)+10s, i am %(age)d years old, i am %(height).2f" % {'name':'jeck','age':26,'height':1.7512}  #定义名字宽度为10,并右对齐.定义身高为浮点类型,保留小数点2位
s4 = "原数: %d, 八进制:%o , 十六进制:%x" % (15,15,15)      #八进制\十六进制转换
s5 = "原数:%d, 科学计数法e:%e, 科学计数法E:%E" %(1000000000,1000000000,1000000000)    #科学计数法表示
s6 = "百分比显示:%.2f %%"  % 0.75     #百分号表示
print(s1)
print(s2)
print(s3)
print(s4)
print(s5)
print(s6)

输出结果:

i am jeck, i am 26 years old
i am jeck, i am 26 years old
i am       jeck, i am 26 years old, i am 1.75
原数: 15, 八进制:17 , 十六进制:f
原数:1000000000, 科学计数法e:1.000000e+09, 科学计数法E:1.000000E+09
百分比显示:0.75 %

format方式

#!/usr/bin/env python
# -*- coding: UTF-8 -*-
#pyversion:python3.5
#owner:fuzj

f1 = "i am {0}, i am {1}d years old".format('Jeck',26)         #采用位置参数来索引
f2 = "i am {name}, i am {age}d years old".format(**{'name':'jeck','age':26})   #采用自定义key来缩影,此时**表示将字典的k/v取出
f3 = "--{name:*^10s}--   =={age:<10.2f}==".format(name='Jeck',age=26.457)   #将name的宽度设置为10,空余的使用*号不全,并居中显示,age类型设置为浮点型,宽度为10.并左对齐
f4 = "原数:{:d}  二进制:{:b}, 八进制:{:o}, 十六进制x:{:x},十六进制X:{:X}".format(15, 15, 15, 15, 15)   #进制转换
f5 = "原数:{:d}, 科学计数法e:{:e}, 科学计数法E:{:E}" .format(1000000000,1000000000,1000000000)    #科学计数法表示
f6 = "原数:{:2F}, 百分号表示{:.2%},  原数:{:d},自动分割表示:{:,}".format(0.75,0.7584,10000000,10000000 )  #百分号表示及自动分割

print(f1)
print(f2)
print(f3)
print(f4)
print(f5)
print(f6)

输出结果:

i am Jeck, i am 26d years old
i am jeck, i am 26d years old
--***Jeck***--   ==26.46     ==
原数:15  二进制:1111, 八进制:17, 十六进制x:f,十六进制X:F
原数:1000000000, 科学计数法e:1.000000e+09, 科学计数法E:1.000000E+09
原数:0.750000, 百分号表示75.84%,  原数:10000000,自动分割表示:10,000,000