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