python⽤(%s%d)格式化字符串与⽤format格式化的区别普通格式化⽅法
1. (%s%d)⽣成格式化的字符串,其中s是⼀个格式化字符串,d是⼀个⼗进制数;
2. 格式化字符串包含两部分:普通的字符和转换说明符,
将使⽤元组或映射中元素的字符串来替换转换说明符;
如果d是元组的话,必须与s中的转换说明符个数⼀致;
如果d是dict的话,每个转换说明符都必须与dict中⼀个有效的键名相关联.
3.
转换说明符,都以%开始输出格式
d,i⼗进制
u⽆符号数
o⼋进制
x⼗六进制或长整数
X⼗六进制
f,e,E浮点数
g,G指数⼩于-4时使⽤
s字符串或者任意对象,同str⽣成的字符串
r同repr⽣成的字符串
4. 在%字符和转换字符之间,可以出现以下修饰符,并且只能按照以下顺序出现,
1. 位于括号中的⼀个键名,⽤于从dict中获取这个key对应的值,如果不存在key,则引发异常;
2. 下⾯中的⼀个或者多个:
1. -,左对齐标志,默认为右对齐;
2. +,表⽰应该包含数字的正负号;
3. 0,表⽰⽤0来填充;
3. 指定最⼩⾃动宽度的数字.转换后的值将被打印在⾄少为这个宽度的字符串中,并且在左边填充空格⾄满字段宽(如果指定了-标志,则在右边
填充);
4. ⼀个⼩数点,⽤于按照精度分割字段宽度;
5. ⼀个数字,指定要打印字符串中最⼤字符个数,浮点数中⼩数点之后的位数或整数的最⼩位数;
6. ⽤于任意宽度的字段中替换数字.如果存在,宽度将从元组的下⼀项开始读取;
#!/usr/bin/python
# -*- coding: utf-8 -*-
#1
a = {"name":'ljs',"age":22,'weight':75}
print "%(name)s %(age)d %(weight)d;"%a  #ljs 22 75;
#将已经定义的变量扩展到字符串中
name = 'ljs'
age = 22
weight = 75
r = "%(name)s %(age)d %(weight)d;"%vars()
print r              #ljs 22 75;
print vars()        #vars()函数包含⼀个此时已定义的所有变量的字典
#2 and 3
a = 'abc'格式化命令format参数
b = 100
c = -100
print "%d"%(a,b)    #error
print "%10s ;"%a    #      abc ;最⼩宽度为10,宽度不⾜10,默认为右对齐,向左补充空格直⾄宽度为10
print "%-10s ;"%a    #abc        ;最⼩宽度为10,宽度不⾜10,-为左对齐标志,向右补充空格直⾄宽度为10
print "%+10s ;"%a    #      abc ;字符串没有符号,so 标志+ 不起作⽤
print "%010s ;"%a    #      abc ;不是数字,不⽤填充0,所以标志0不起作⽤
print "%10d ;"%b    #      100 ;最⼩宽度为10,宽度不⾜10,默认为右对齐,向左补充空格直⾄宽度为10
print "%-10d ;"%b    #100        ;最⼩宽度为10,宽度不⾜10,-为左对齐标志,向右补充空格直⾄宽度为10
print "%+10d ;"%b    #      +100 ;打印出符号
print "%+10d ;"%c    #      -100 ;打印出符号
print "%+010d ;"%b  #+000000100 ;填充0⾄宽度为10
#4 5
a = 1.23456
print "%f"%a        #1.234560;正常打印
print "%3f"%a        #1.234560;最⼩宽度为3,但是长度已经超过了3,so正常打印
print "%10f"%a      #  1.234560;最⼩宽度为10,宽度不⾜10,默认为右对齐,向左补充空格直⾄宽度为10
print "%.3f"%a      #1.235;⼩数点后的数字为精度,⼩数点后保留3位
print "%.10f"%a      #1.2345600000;⼩数点后位数不⾜10,补0⾄位数为10
#6
a = 123456.7890123456
print "%*.*f;"%(15,5,a) #  123456.78901;第⼀个*为最⼩宽度,第⼆个*为⼩数点后⾯的精度
print "%-*.*f;"%(15,5,a)#123456.78901  ;
⾼级字符串格式化
1. 字符串的format()函数,该⽅法收集位置参数和关键字参数的任意集合,并使⽤它们的值来替换字符串中的占位符;
2. 形式为{n}(n为整数)的占位符将被format()⽅法第n个参数所代替;
形式为{name}的占位符将被参数中为name的参数所替代;
如果要⽤format()输出{xx},必须使⽤{{xx}},否则会因为不到对应的参数值⽽报错;
3. 可以指定格式说明符,对输出进⾏更加精确地控制.
给每个占位符添加可选的格式说明符号,如{name:format_spec}.这种说明符可指定列宽,⼩数位和对齐⽅式.
⼀般格式[fill,align,sign,0,width,.precision,type],每⼀处都是可选的.
1. fill:是⼀个可选的填充字符,⽤于填充空⽩,默认为空格;
2. align,对齐⽅式.<,>,^分别代表左,右,居中对齐,默认为右对齐;
3. sign,取值为:
1. +,所有数字签名都要加上符号;
2. -,默认值,只在负数签名加符号;
3. 空格,在正数前⾯加上⼀个空格;
4. 0,在宽度前⾯加0表⽰⽤0来填充数值前⾯的空⽩;
5. width,宽度;
6. .precision,精度的位数;
7. type,数据类型,如d(整数),s(字符串)等
4. 某些情况下,可能只是要格式化对象的str()或repr()表⽰,需要绕过__format__()⽅法.为此,可以在格式说明符前⾯添加!r或!s说明符,
#!/usr/bin/python
# -*- coding: utf-8 -*-
'''
help(str.format)
Help on method_descriptor:
format(...)
S.format(*args, **kwargs) -> string
Return a formatted version of S, using substitutions from args and kwargs.
The substitutions are identified by braces ('{' and '}').
'''
print "{{a}}".format()                  #{a}
print "{a}".format()                    #error,⾥⾯没有为a的参数
print "{a} - {b}".format(a = 100,b = 200)#100 - 200
print "{0},{0}".format(11,22)            #11,11
print "{0},{0},{1},{2}".format(11,22,33) # 11,11,22,33  中括号⾥⾯的数代表第⼏个参数
print "{0:3d},{1:4s},{1:5s},{2}".format(11,"a",33) # ' 11,a  ,a    ,33'
print "{0:=>+011.3f};".format(12.12345)  #====+12.123;⽤=来填充,右对齐,因为已经⽤=来填充了,0⽆效,宽度11,⼩数点精度后精度为3,类型为浮点数print "{0:>+011.3f};".format(12.12345)  #0000+12.123;
a = "test"
print "{0:^10}".format(a)                #test
print "{0!s:^10}".format(a)              #test
print "{0!r:^10}".format(a)              #'test'
#通过下标也⾏
a=[1,2]
print '{0[0]},{0[1]}'.format(a)          #1,2
#对象属性
class Test(object):
def __init__(self,name,age):
self.name,self.age = name,age
def __str__(self):
return 'This boy is {self.name},is {self.age} old'.format(self=self)
def str(self):
return self.__str__()
a = Test('lilei',12)
print str(a)    #This boy is lilei,is 12 old
print a.str()  #This boy is lilei,is 12 old
#format函数单独使⽤
format('abc',"10s")    #'abc      '
还有⼀种情况就是当字符串变量有中⽂时,使⽤%s⽅式容易出现 ascii 转换错误问题,是因为python2.7默认编码是ascii导致,只需更改默认编码即可,
import sys
reload(sys)
sys.setdefaultencoding('utf-8')

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。