Str.format()方法

自学python如何成为大佬(目录):https://blog.csdn.net/weixin_67859959/article/details/139049996?spm=1001.2014.3001.5501

语法参考

在Python2.6之后,提供了字符串的format()方法对字符串进行格式化操作。format()功能非常强大,格式也比较复杂,具体语法分解如下:

{参数序号: 格式控制标记}.format(*args,**kwargs)

l 参数序号:参数序号其实是位置参数或关键字参数传递过来的参数变量,对参数序号进行格式控制标记设置其实就是对位置参数或关键字参数进行格式化处理。参数序号可以为空值,为空值时一定对应的是位置参数,并且在顺序上和位置参数一一对应。

l 格式控制标记:用来控制参数显示时的格式,和format()函数的format_spec参数是一样的,包括:<填充><对齐><宽度>,<.精度><类型>6 个字段,这些字段都是可选的,可以组合使用。参数序号和格式设置标记用大括号({})表示,可以有多个。{}表示按照顺序匹配位置参数,{n}表示取位置参数索引为n的值

l *args:位置参数,是一个元组,可以为多个值。其和参数序号在位置上是一一对应的,数量上是一致的。

l **kwargs是关键字参数,是一个字典,其通过序号和参数序号进行对应,可以一对一,也可以一对多。使用关键字参数时,参数序号和关键字参数不一定数量一致。

如图1所示为通过位置参数或关键字参数进行格式化处理的流程。

图1 格式化处理的流程

下面具体介绍如何通过位置参数或关键字参数进行格式化操作。

其中,参数序号为传入的参数,格式设置模板是一个由字符串和格式控制说明字符组成的字符串,用来对传入的参数进行格式化设置。格式设置模板用大括号({})表示,可以有多个,其对应format()方法中逗号分隔的参数。

常量可以是符号、文字,甚至是一段话,根据程序开发需要进行设置。灵活使用常量,可以更大范围发挥format()方法的功效。

索引序号与参数映射

'{索引序号: 格式控制标记}'.format(*args,**kwargs)

l args是位置参数,是一个元组

l kwargs是关键字参数,是一个字典

l {}表示按照顺序匹配位置参数,{n}表示取位置参数索引为n的值

(1)通过位置参数映射

就是按照位置顺序用位置参数替换前面的格式字符串的占位符。位置参数按照序号匹配,关键字参数按照名称匹配(注:按照位置填充,大括号只是占位符注,一一对应,按照位置输出结果)

l 索引序号为空

如果索引序号为空,索引序号与位置参数按照从左到右的顺序上可以建立映射,实现对传入参数的格式化处理。如索引序号和格式设置标记均为空值时,直接输出位置参数。代码如下:

'{}'.format('中国') # 输出为"中国"

位置参数与索引序号对应关系如图2所示。

图2 位置参数与索引序号对应关系

位置参数可以为两个或更多,其对应的索引序号也应该和位置索引一一对应。如果索引序号和格式设置标记均为空值时,其实就是直接连接位置参数的字符串。如通过format()方法连接字符串 "中国"、"1949"及"70",代码如下:

'{}{}'.format('中国','1949') # 输出为"中国1949"

'{}{}{}'.format('中国','1949','70') # 输出为"中国194970"

位置参数对应关系如图3和图4所示。

图3 传递两个参数的情况

图4 传递三个参数的情况

通过常量可以直接连接或修饰各个序号索引之间的关系,如分别通过字符串常量":"和"<<<<<<<<<<"连接"中国"、"1949" 及"70",代码如下:

'{}:{}:{}'.format('中国','1949','70') # 输出为"中国:1949:70"

'{}<<<<<<{}<<<<<<{}'.format('中国','1949','70') # 输出为"中国<<<<<<1949<<<<<<70"

通过常量连接或修饰各个序号索引之间的关系如图5所示。

图5 通过常量连接或修饰各个序号索引之间的关系

可以通过不同的汉字常量对位置参数进行修饰,如通过"建国于"、"到2019年已经" 、"年"连接"中国"、"1949" 及"70",代码如下:

'{}建国于{}年,到2019年已经{}年!'.format('中国','1949','70')

输出为:

中国建国于1949年,到2019年已经70年!

通过不同的汉字常量对位置参数进行修饰的对应关系如图6所示。

图6 通过不同的汉字常量对位置参数进行修饰

l 索引序号不为空(同一个参数可以填充多次)

如果索引序号不为空,可以通过设置索引序号内的值和位置参数的索引值进行对应,即通过{n}对位置参数索引为n的值进行对应,从而实现对传入的位置参数进行格式化处理。如格式化2019年世界500强企业名单的第一名,代码如下:

'排名:{0} 企业:{1} 收入:{2} 利润:{3}'.format('1','沃尔玛','5144.05','66.7')

使用print()函数输出结果如下:

排名:1 企业:沃尔玛 收入:5144.05 利润:66.7

索引序号和位置参数不一定要按照这顺序一一对应,可以根据程序需要对索引序号内的位置索引进行设置,本例的索引序号和位置参数是一一对应的,对应关系如图7所示。

图7 索引序号和位置参数的对应关系

改变索引序号的,可以通过设置索引序号和位置参数的索引值对应,即通过{n}对位置参数索引为n的值进行对应,从而实现对传入的位置参数进行格式化处理。如格式化2019年世界500强企业名单的第一名,代码如下:

'企业:{1} 收入:{2} 排名:{0}'.format('1','沃尔玛','5144.05','66.7')

使用print()函数输出结果如下:

企业:沃尔玛 收入:5144.05 排名:1

本例索引序号和位置参数是非对应的,位置参数"沃尔玛"的索引为1,位置参数"5144.06"的索引为2,位置参数"1"的索引为0,根据程序需要将相应的索引值通过索引序号进行了对应,如图8所示。

图8 索引值和索引序号的对应关系

索引序号的值可以重复,即多个索引序号的值可以是同一个位置参数的索引。如输出2018年和2019年世界500强企业名单的第一名企业沃尔玛,代码如下:

'2018:{0} 收入:{2} 2019:{0} 收入:{1}'.format('沃尔玛','5144.05','5003.43')

位置参数"沃尔玛"的索引为0,位置参数"5144.06"为2019年的收入(亿美元),位置参数"5003.43"为2018年的收入。在代码中,位置参数"沃尔玛"的索引为0在索引序号引用了两次,如图9所示。

图9 位置参数与索引序号的对应关系

同一个位置参数可以填充多次,下面是索引序号和位置参数进行映射的示例:

print('{0}, {1}, {2}'.format('I', 'B', 'M')) # 输出结果为:I, B, M

print('{}, {}, {}'.format('I', 'B', 'M')) # 输出结果为:I, B, M

print('{2}{2}{0}{1}{1}'.format('I', 'B', 'M')) # 输出结果为:MMIBB

print('{0}{1},{0}{2}'.format('I','B','M')) # 输出结果为:IB,IM

print('{2}{1}{0}-{0}{1}{2}'.format('I', 'B', 'M')) # 输出结果为:MBI-IBM

如果位置参数不确定,也可以使用"*args"形式的位置参数来进行映射,*args可以将*号后面的字符串拆解成一个一个元素,如*'IBM',将"IBM"拆解成'I','B','M',下面代码实现的效果是一样的。

print('{2}, {1}, {0}'.format(*'IBM')) # 输出 M, B, I

print('{2}, {1}, {0}'.format('I', 'B', 'M')) # 输出 M, B, I

位置参数的值可以来自元祖或表,然后使用"*args"形式的位置参数来进行映射,如:

mingri=['www','mingrisoft','com']

print('{0}.{1}.{2}'.format(*mingri)) # 输出结果为:www.mingrisoft.com

如果索引序号设置字符串过长,可以使用变量代替索引序号设置字符串,如:

order='排名:{} 企业名称:{} 营业收入:{}万美元 利润:{}万美元'

print(order.format('1','沃尔玛','51440500','667000'))

输出结果为:

排名:1 企业名称:沃尔玛 营业收入:51440500万美元 利润:667000万美元

(2)通过关键字参数映射(关键字参数或命名参数)

索引序号按照关键字参数名称进行映射,kwargs是关键字参数,是一个字典{xxx}表示在关键字参数中搜素名称一致的。将元祖或字典打散成关键字参数给函数(通过和*或者**)format(),进行非常灵活的映射关系。

print('产品:{name}价格:{price}'.format(spec='6G+128G',name='Mate20',price=3669)) print('***{name}***, {price} '.format(spec='6G+128G',name='Mate20',price=3669))

user = {'net':'双4G','name':'Mate 20','price':3669,'spec':'6GB+128G'}

print('{name},{net},{spec},{price}'.format(**user))

输出结果为:

产品:Mate20价格:3669

***Mate20***, 3669

Mate 20,双4G,6GB+128G,3669

位置参数和关键字参数可以混合使用,如:

print('{server}.{1}.{0}'.format('com','mingrisoft',server= 'www'))

输出结果为:

www.mingrisoft.com

(3)通过元素进行映射

对于一些需要在字符串或元祖中截取部分元素进行格式化处理的情况,可以使用切片技术,但只能单个元素提取,如0[1],0[2],不能截取多个元素,如0[0:3],0[:2]等。(说明,0[1]查找位置参数索引为0 的元组中索引为1的元素)。代码举例如下:

print('{0[1]}--{0[0]}'.format(('猛龙','01')))

print('{0[0]}.{0[1]}.{0[2]}'.format(['www','mingrisoft','com']))

print('{0[2]}.{0[1]}.{0[0]}'.format('张三丰'))

print('{0[0]} {0[1]} {0[2]}'.format('www.mingrisoft.com'.split('.')))

输出结果如下:

01--猛龙

www.mingrisoft.com

丰.三.张

www mingrisoft com

在对元素进行格式化时,利用转义符可以对格式化的数据进行灵活的操作,如分别连接元祖中的数据,使用"\n"转义符实现分行对NBA球队进行输出。代码如下:

print('{0[1]}--{0[0]}\n{1[1]}--{1[0]}'.format(('猛龙','01'),('勇士','02')))

输出结果如下:

01--猛龙

02--勇士

print('{0[1][1]}\n{0[0][1]}'.format((('www','mingrisoft','com'),('www','huawei','com'))))

输出结果如下:

huawei

mingrisoft

可以对不同元祖中的对应元素进行提取,实现相应数据的对应输出。如提取元祖中网址中的网址信息,代码如下:

print('{0[1]}、{1[1]}'.format(('www','mingrisoft','com'),('www','huawei','com')))

mingrisoft、huawei

(4)通过组合映射

在格式化数据时,可以根据位置参数或关键字参数的制定元素,通过索引序号进行灵活的数据组合映射,以达到程序的需要。如将两个元祖中的元素组合,格式化输出三大互联网公司,代码如下:

print('{1[0]}{0[0]}\n{1[1]}{0[1]}\n{1[1]}{0[2]}\n{1[0]}{0[3]}'.format(('阿里巴巴','亚马逊','谷歌','腾讯','IBM'),('中国','美国')))

输出结果为:

中国阿里巴巴

美国亚马逊

美国谷歌

中国腾讯

也可以将多个未知参数中的元素进行组合,如将姓名等位置参数进行组合,生成新的姓名字符串,代码如下:

print('{0[0]}{1[0]}{2[0]}'.format('张王李赵','世常明延','国成微远'))

输出结果如下:

张世国

(5)通过元祖映射

通过元祖可以很好地实现索引序号与格式化数据的映射,如:

list = ['明日科技', 'www.mingrisoft.com']

print("公司名称:{0[0]}, 网址:{0[1]}".format(list)) # "0" 对应字典的索引值

info= ['joy', 22, '1.73']

print('My name is {0[0]}, age is {0[1]}, height is {0[2]}'.format(info))

film= (('复仇者联盟4:终局之战',8.6,2019,2793),('阿凡达',8.7,2009,2788),('泰塔尼克号',9.4,1997,2187))

print( '票房最高: {0[0][3]}, 评分最高: {0[2][1]},最新发行:{0[0][2]}'.format(film))

data = [4, 8, 15, 16, 23, 42]

print('{d[4]} {d[5]}'.format(d=data))

输出结果为:

公司名称:明日科技, 网址:www.mingrisoft.com

My name is joy, age is 22, height is 1.73

票房最高: 2793, 评分最高: 9.4,最新发行:2019

(6)通过字典映射

利用字典进行映射是比较常用的格式化操作的方法,可以通过字典的参数的items访问。

info= {'name': 'joy', 'age': 22, 'height':1.68}

print('name : {0[name]}, age :{0[age]}, height: {0[height]}'.format(info))

order= {'a001': 'joy', 'a002': 'jack', 'a003':'may', 'a004':'jobs'}

fatstr='{0['+random.choice((',').join(info).split(','))+']}'

print(fatstr.format(order))

person = {'name': 'joy', 'age': 22}

print('{p[name]} {p[age]}'.format(p=person))

输出结果为:

name : joy, age :22, height: 1.68

joy

joy 22

元祖和字典都支持命名占位符,如:

data = {'a001': '英国SAS', 'b001': '美国三角洲部队','c001': '俄罗斯阿尔法部队'}

print('{b001} {c001}'.format(**data))

输出结果为:

美国三角洲部队 俄罗斯阿尔法部队

(7)通过循环嵌套映射

通过循环语句可以批量循序建立映射关系,如下批量建立虚拟姓名:

new=('张王李赵','世常明延','国成微远')

for i in range(4):

print('{0}{1}{2}'.format(new[0][i],new[1][i],new[2][i]))

class Plant(object):

type = 'tree'

kinds = [{'name': 'oak'}, {'name': 'maple'}]

print('{p.type}: {p.kinds[0][name]}'.format(p=Plant()))

输出结果为:

张世国

王常成

李明微

赵延远

tree: oak

(8)通过传入对象映射

class Person:

def init(self,name,age):

self.name,self.age = name,age

def str(self):

return '我叫{self.name}, 今年{self.age}岁了'.format(self=self)

print(str(Person('joy', 22)))

输出结果为:

我叫joy, 今年22岁了

(9)灵活应用占位符

print('{0:{fill}{align}12}'.format("python", fill='#', align='^'))

for num in range(1,6):

for base in "dXob":

print("{0:{width}{base}}".format(num, base=base, width=6), end=' ')

print()

输出结果为:

###python###

1 1 1 1

2 2 2 10

3 3 3 11

4 4 4 100

5 5 5 101

格式化模板标签

'{索引序号: 格式控制标记}'.format(*args,**kwargs)

本节重点讲解格式控制标记,格式控制标记用来控制参数显示时的格式,包括:<填充><对齐><宽度>,<.精度><类型>6 个字段,这些字段都是可选的,可以组合使用。其对应关系如图10所示。

图10 格式控制标记与显示格式的对应关系

格式模板中的格式标记符即可以简单、快速对数据进行格式化处理,也可以进行复杂的自动化处理和计算。

1)fill,可选参数,指"width"内除了参数外的字符采用什么方式表示,默认采用空格,可以通过<填充>更换,填充字符只能有一个。

s = "PYTHON"

print("{0:30}".format(s))

print("{0:>30}".format(s))

print("{0:*^30}".format(s))

print("{0:-^30}".format(s))

print("{0:3}".format(s))

输出结果为:

PYTHON

PYTHON

************PYTHON************

------------PYTHON------------

PYTHON

print("{a:*^8}".format(a="mr")) # 输出***mr***

print("{:0>8}".format("866"))

print("{:$>8}".format("866"))

print("{:0>8}".format("866"))

print("{:-<8}".format("866"))

#中间对齐方式中如果出现字符两侧无法平均分配填充符,字符后填充符可以多填充

print("{:-^8}".format("866"))

print("{:*<30}>".format("www.mingrisoft.com"))

输出结果为:

***mr***

00000866

$$$866 00000866 866----- --866--- www.mingrisoft.com\*\*\*\*\*\*\*\*\*\*\*\*\> 2)align,可选参数,可供选择的值有:\<,\>,\^或=。指参数在\<宽度\>内输出时的对齐方式,分别使用\<、\>、\^和=表示左对齐、右对齐、居中对齐和在符号后进行补齐。需要注意的是,如果align参数为空,对于字符串,默认左对齐。对于数字,默认右对齐。 l \< (如果是字符串,默认左对齐)左对齐 l \^ 中间对齐 l \> (如果是数字,默认右对齐)右对齐 l = (只用于数字)在符号后进行补齐 print("{:10}".format('18')) print("{:10}".format(18)) print("{:\<10}".format('18')) print("{:\<10}".format(18)) print("{:\>10}".format('18')) print("{:0\>10}".format('18')) print('{:A\>10}'.format('18')) print("{:\^10}".format('18')) print('{:0=10}'.format(-18)) print('{:0\<10}'.format(-18)) print('{:0\>10}'.format(-18)) print('{:0=10}'.format(18)) 输出结果为: 18 18 18 18 18 0000000018 AAAAAAAA18 18 -000000018 -180000000 0000000-18 0000000018 注意:zfill()方法也可以返回指定长度的字符串,原字符串右对齐,前面填充0。 zfill()方法语法:str.zfill(width) 参数width指定字符串的长度。原字符串右对齐,前面填充0。 返回指定长度的字符串。 print("11".zfill(5)) 结果输出为: 00011 3)sign,可选参数,sign可以使用 "+" \| "-" \| " "。+表示正号, -表示负号宽度指当前槽的设定输出字符宽度,如果该槽参数实际值比宽度设定值大,则使用参数实际长度。如果该值的实际位数小于指定宽度,则按照对齐指定方式在宽度内对齐,默认以空格字符补充。 s = 3.1415926 t=-3.1415926 print("{:+25}".format(s)) #左对齐,默认 print("{:\^25}".format(s)) #居中对齐 print("{:\>-25}".format(s)) #右对齐 print("{:\*\^ 25}".format(t)) #居中对齐且填充\*号 print("{:+\^25}".format(t)) #居中对齐且填充+号 print("{:十\^25}".format(t)) #居中对齐且填充汉字"十" print("{:\^+1}".format(t)) #z指定宽度为1,不足变量s的宽度 输出结果为: +3.1415926 3.1415926 3.1415926 \*\*\*\*\*\*\*-3.1415926\*\*\*\*\*\*\*\* +++++++-3.1415926++++++++ 十十十十十十十-3.1415926十十十十十十十十 -3.1415926 4)#和0,可选参数,#为进制标志,对于进制数,在进制符前加#,输出时会带上进制前缀,即显示0b,0o,0x。0为填充0,设置width时,没设填充值,加上0,填充0指定位置用0填充。如: print("{:0\>5}".format('18')) print("{:#x}".format(50)) # 在进制符前加#,输出时会带上进制前缀 print("{:#o}".format(12)) # 在进制符前加#,输出时会带上进制前缀 print("{:#b}".format(22)) # 在进制符前加#,输出时会带上进制前缀 print("{:\>#8x}".format(50)) # 在进制符前加#,输出时会带上进制前缀 print("{:=#10o}".format(12)) # 在进制符前加#,输出时会带上进制前缀 输出结果为: 00018 0x32 0o14 0b10110 0x32 0o 14 5)Width,可选参数, integer 是数字宽度,表示总共输出多少位数字。通常和align参数配合使用,示例如下:指当前槽的设定输出字符宽度,如果该槽对应的format()参数长度比\<宽度\>设定值大,则使用参数实际长度。如果该值的实际位数小于指定宽度,则位数将被默认以空格字符补充。如: print('%+6s' % '明日') # 字符串左对齐 print('%+6d' % -3.14) # 格式化为整数,左对齐 print('%-6s' % '明日') # 字符串左对齐 print('%-6d' % -3.14) # 格式化为整数,左对齐 print('% 6s' % '明日') # 字符串左对齐 print('%06d' % 3.14) # 格式化为整数,左对齐 输出结果为: 明日 -3 明日 -3 明日 000003 6)千位符,千位符用逗号(,),用于显示数字的千位分隔符,例如: print("{0:\^12,}".format(31415926)) print("{0:-\^12,}".format(3.1415926)) print("{0:\*\^12,}".format(31415.926)) 输出结果为: 31,415,926 -3.1415926-- \*31,415.926\* 7) .precision,可选参数,设置浮点数或字符串的精度。对于浮点数来说,用于设置浮点数的精度,即小数点后保留的位数。对于字符串来说,就是截取字符串的位数。表示两个含义,由小数点(.)开头。对于浮点数,精度表示小数部分输出的有效位数。对于字符串,精度表示输出的最大长度。 print("{0:.2f}".format(12345.67890)) print("{0:H\^20.3f}".format(12345.67890)) print("{0:.4}".format("PYTHON")) 结果输出为: 12345.68 HHHHH12345.679HHHHHH PYTH 8)type,可选参数,表示获取对应类型的值并格式化到指定位置。格式符为真实值预留位置,并控制显示的格式。格式符可以包含有一个类型码,用以控制显示的类型,主要的格式符有: l s,字符串 (采用str()的显示)。 l r,字符串 (采用repr()的显示)。 l c,整数:将数字转换成其unicode对应的值,10进制范围为 0 \<= i \<= 1114111(py27则只支持0-255);字符:将字符添加到指定位置。 l o,将整数转换成八进制表示,并将其格式化到指定位置。 l x,将整数转换成十六进制表示,并将其格式化到指定位置。 l b 将整数转换成二进制整数,并将其格式化到指定位置。 l d,将整数、浮点数转换成十进制表示,并将其格式化到指定位置。 l e,将整数、浮点数转换成科学计数法,并将其格式化到指定位置(小写e)。 l E,将整数、浮点数转换成科学计数法,并将其格式化到指定位置(大写E)。 l f, 将整数、浮点数转换成浮点数表示,并将其格式化到指定位置(默认保留小数点后6位)。 l g,自动调整将整数、浮点数转换成 浮点型或科学计数法表示(超过6位数用科学计数法),并将其格式化到指定位置(如果是科学计数则是e;)。 l G,自动调整将整数、浮点数转换成 浮点型或科学计数法表示(超过6位数用科学计数法),并将其格式化到指定位置(如果是科学计数则是E;)。 l %,当字符串中存在格式化标志时,需要用 %%表示一个百分号。 如果类型参数未提供,则和调用str(value)效果相同,转换成字符串格式化。如: print("{}".format(12345.67890)) print("{0:\>12}".format(12345.67890)) 结果输出为: 12345.6789 12345.6789 对于字符符串类型,可以提供的参数有 's' print("{:s}".format('3.1415926')) print("{0:\>12s}".format('mingri')) print("{0:\>12s}\\n{1:\>6s}".format('mingri','mr')) 结果输出为: 3.1415926 mingri mingri mr 整形数值可以提供的参数有 'b' 'c' 'd' 'o' 'x' 'X' 'n' None,如: print("{:c}".format(1221)) print("{:4d}".format(3145926)) print("{:b}".format(31)) print("{:o}".format(31)) print("{:x}".format(31)) print('{0:o} :{0:x}:{0:o}'.format(31)) 结果输出为: Ӆ 3145926 11111 37 1f 37 :1f:37 #浮点数可以提供的参数有 'e' 'E' 'f' 'F' 'g' 'G' 'n' '%' None print('{:e}'.format(314159267)) #科学计数法,默认保留6位小数 print('{:0.2e}'.format(314159267)) #科学计数法,指定保留2位小数 print('{:f}'.format(314159267)) # 小数点计数法,默认保留6位小数 print('{:0.2f}'.format(314159267)) #小数点计数法,指定保留2位小数 print('{0:0.2f}\\n{0:0.8f}'.format(314159267)) #小数点计数法,指定保留小数位数 print('{:0.2F}'.format(314159267)) #小数点计数法,指定保留2位小数 print('{0:0.2F}\\n{0:0.8f}'.format(314159267)) #小数点计数法,指定小数位数 结果输出为: 3.141593e+08 3.14e+08 314159267.000000 314159267.00 314159267.00 314159267.00000000 314159267.00 314159267.00 314159267.00000000 #g的格式化比较特殊,假设p为格式中指定的保留小数位数,先尝试采用科学计数法格式化,得到幂指数exp,如果-4\<=exp\8d}'.format(+0X1234)) # 16进制数1234转换成10进制数,右对齐,不足用\* 输出结果为: 90 29 28 00042798 \*\*\*\*4660 保留进制前缀,#为进制标志,对于进制数,在进制符前加#,输出时会带上进制前缀,即显示0b,0o,0x,示例代码如下: print("{:#x}".format(123)) # 在进制符前加#,输出时会带上进制前缀 print("{:#o}".format(28)) # 在进制符前加#,输出时会带上进制前缀 print("{:#b}".format(15)) # 在进制符前加#,输出时会带上进制前缀 输出结果为: 0x7b 0o34 0b1111 锦囊2 格式化十进制整数 格式化整形数值可以提供的参数有'd'、 'n',两者相同相同。和format()函数不同,使用str.format()方法格式化数值时,被格式化的数值必须是整数,不能是浮点数。常用应用如下: print('{:}'.format(122)) # 格式参数为空,默认为10进制 print('{:d}'.format(122)) # 原来是十进制数,转换后为原值 print('{:6d}'.format(122)) # 转换为6位十进制数,空余部分用空格填充 print('{:-6d}'.format(122)) # 转换为6位带符号十进制数,在符号前填充空余部分空格 print('{:08d}'.format(122)) # 转换为8位十进制数,空余部分填充0 print('{:+8d}'.format(122)) # 转换为8位带符号十进制数,在符号前填充空余部分空格 print('{:-8d}'.format(122)) # 转换为8位十进制数,空余部分填充空格 print('{:=8d}'.format(-122)) # 转换为8位十进制数,负号后空余部分填充空格 print('{:=8d}'.format(122)) # 转换为8位十进制数,空余部分填充空格 print('{:\*\<8d}'.format(122)) # 转换为8位十进制数,左对齐,空余部分填充\* print('{:#\>8d}'.format(122)) # 转换为8位十进制数,右对齐,空余部分填充# print('{:n}'.format(122)) # 原来是十进制数,转换后为原值 print('{:6n}'.format(122)) # 转换为6位十进制数,空余部分用空格填充 print('{:-6n}'.format(122)) # 转换为6位带符号十进制数,在符号前填充空余部分空格 输出结果为: 122 122 122 122 00000122 +122 122 - 122 122 122\*\*\*\*\* #####122 122 122 122 对于整数来说,加、减、乘、除是最基本的操作,对整数进行格式化后可以直接连接成算数式。下面是一些简单的计算操作,代码如下: print('{:d}={:2d}={:3d}'.format(122,122,122))# 8位整数显示,不足部分整数前用空格填充 print('{:4d}+{:4d}={:4d}'.format(25,10,35)) # 格式化为带符号整数显示数据 add1=\[12,23,35,10,8\] # 加数 add2=\[7,19,6,211,790\] # 被加数 for i in range(5): # 循环输出计算式 print('{:\<5d}+{:5d}={:5d}'.format(add1\[i\],add2\[i\],add1\[i\]+add2\[i\])) # 加数设成左对齐 输出结果为: 122=122=122 25+ 10= 35 12 + 7= 19 23 + 19= 42 35 + 6= 41 10 + 211= 221 8 + 790= 798 锦囊3 格式化浮点数 对于浮点数类型,可以提供的格式化参数有 'e' 、'E'、 'f' 、'F'、 'g'、 'G' 、'%' 等。本锦囊主要讲解用 f 格式化浮点类型的方法。使用 f 格式化浮点类型时,可以在其前边加上精度,控制输出浮点数的值;可以设置宽度控制数字的占位宽度。如果输出位数大于宽度,就按实际位数输出,如果输出位数小于宽度,则用占位符填充不足部分;也可以为浮点数指定符号,+ 表示在正数前显示 +,负数前显示 -; (空格)表示在正数前加空格,在幅负数前加 -;- 与什么都不加({:f})时一致:{:f}默认保留6位小数。 {:。3f}表示浮点数的精度为3(小数位保留3位),{:.f}是错误,必须在小数点后书写数字。常用示例代码如下: print('{:f}'.format(628)) # 格式化为保留1位小数的浮点数 print('{:.1f}'.format(628)) # 格式化为保留1位小数的浮点数 print('{:.2f}'.format(628)) # # 格式化为保留2位小数的浮点数 print('{:.1f}'.format(3.14159)) # 格式化为保留1位小数的浮点数 print('{:.5f}'.format(3.14159)) # 格式化为保留5位小数的浮点数 print('{:\>8.3f}'.format(-3.14159)) # 格式化为保留1位小数的浮点数 print('{:\<8f}'.format(3.1415926535898,'f')) # 默认精度保留6位小数 print('{:f}\>{:.4f}\>{:.2f}'.format(3.1415926,3.1415926,3.1415926)) print('{:2f}-{:2f}={:2f}'.format(12.2345,10,2.2345)) # 格式化为带符号整数显示数据 输出结果为: 628.000000 628.0 628.00 3.1 3.14159 -3.142 3.141593 3.141593\>3.1416\>3.14 12.234500-10.000000=2.234500 在计算式中,可以通过格式化统一浮点数的精度(小数位数)。通常是将浮点数格式化为包含两位小数的浮点数。下面是一些经典的应用,代码如下: one=\[3.2345,6,5.123,12.5678,21\] # 计算数 two=\[18.54,43.67564,3.1315,21.21,7.543\] # 计算数 thr=\[9.1287,1.876,6.345,21.654,7\] # 计算数 str='{:.2f}{:}{:.2f}{:}{:.2f}={:.2f}' **for** i **in**range(5): # 循环输出计算式 str=('{0:.2f}+{1:.2f}\*{2:.2f}={3:.2f}') x='{:.2f}' # 计算精度 all=float(x.format(one\[i\]))+float(x.format(two\[i\]))\*float(x.format(thr\[i\])) print(str.format(one\[i\],two\[i\],thr\[i\],all)) 输出结果为: 3.23+18.54\*9.13=172.50 6.00+43.68\*1.88=88.12 5.12+3.13\*6.34=24.96 12.57+21.21\*21.65=471.77 21.00+7.54\*7.00=73.78 锦囊4 格式化百分数 在格式化解释中单独或者在精度之后添加"%"号,可以实现用百分数显示浮点数,如: print('{:%}'.format(0.161896)) # 将小数格式化成百分数 print('{:.2%}'.format(0.161896)) # 格式化为保留两位小数的百分数 print('{:.6%}'.format(0.0238912)) # 格式化为保留六位小数的百分数 print('{:.2%}'.format(2/16)) # 格式化为保留两位小数的百分数 print('{:.1%}'.format(3.1415926)) # 格式化为保留一位小数的百分数 print('{:.0%}'.format(0.161896)) # 格式化为保留整数的百分数 print('{:8.6%}'.format(0.0238912)) # 格式化为保留六位小数的八位百分数 print('{:8.3%}'.format(0.0238912)) # 格式化为保留三位小数的八位百分数 输出结果为: 16.189600% 16.19% 2.389120% 12.50% 314.2% 16% 2.389120% 2.389% 锦囊5 格式化科学记数法 如果要将浮点数采用科学技术法表示,可以在格式化解释中使用"e"和"E"或者"g"和"G"。'e' 为通用的幂符号,用科学计数法打印数字,用'e'表示幂。使用'g'时,将数值以fixed-point格式输出。当数值特别大的时候,用幂形式打印。 #####e和E print('{:e}'.format(3141592653589)) # 科学计数法,默认保留6位小数 print('{:e}'.format(3.14)) # 科学计数法,默认保留6位小数 print('{:e}'.format(3.14,'0.4e')) # 科学计数法,默认保留6位小数 print('{:0.2e}'.format(3141592653589)) #科学计数法,保留2位小数 print('{:0.2E}'.format(3141592653589)) #科学计数法,保留2位小数,大写E表示 #####g和G print('{:F}'.format(3.14e+1000000)) #小数点计数法,无穷大转换成大小字母 print('{:g}'.format(3141592653589)) #科学计数法,保留2位小数 print('{:g}'.format(314)) #科学计数法,保留2位小数 print('{:0.2g}'.format(3141592653589)) #科学计数法,保留2位小数,大写E表示 print('{:G}'.format(3141592653589)) #小数点计数法,无穷大转换成大小字母 print('{:g}'.format(3.14e+1000000)) #小数点计数法,无穷大转换成大小字母 输出结果为: 3.141593e+12 3.140000e+00 3.140000e+00 3.14e+12 3.14E+12 INF 3.14159e+12 314 3.1e+12 3.14159E+12 inf 锦囊6 格式化金额 format()函数提供千位分隔符用逗号还能用来做金额的千位分隔符。如果要实现通常格式化后金额前面带上相关货币的符号,需要在该函数前面手动加上相应货币符号。如: print('${:.2f}'.format(1201398.2315)) # 添加美元符号,小数保留两位 print(chr(36) + '{:.2f}'.format(1201398.2315)) # ASCII码添加美元,小数保留两位 print( '¥{:,.2f}'.format(1201398.2315)) # 添加人民币符号,用千位分隔符进行区分 print( '£{:,.2f}'.format(888800)) # 添加英镑符号,用千位分隔符进行区分 print( '{:.2f}'.format(123.6612)) # 添加欧元符号,保留两位小数,千位分隔 print( chr(0x20ac) +'{:,.2f}'.format(1201398.2315)) # 使用16进制编码添加欧元 print(chr(36) + '{:.2f}'.format(1201398.2315))# ASCII码加美元符号,小数保留两位 输出效果为: $1201398.23 $1201398.23 ¥1,201,398.23 £888,800.00 123.66 1,201,398.23 $1201398.23 锦囊7 格式化字符 格式化字符主要包括截取字符串,字符串对齐方式显示,填充字符串等几个方面,下面举例如下: print('{:M\^20.3}'.format('PYTHON')) #截取3个字符,宽度20居中,不足用'M'填充 print('{:10}'.format("PYTHON",'10')) # 默认居左,不足部分用' '填充 print('{:.3}'.format('mingrisoft.com')) # 截取3个字符,默认居左显示 print('{:\>10}'.format("PYTHON")) # 居右显示,不足部分用' '填充 s='mingrisoft.com' print('{:\>20}'.format(s)) # 右对齐,不足指定宽度部分用0号填充 print('{:\>4}'.format(s)) # 右对齐,因字符实际宽度大于指定宽度4,不用填充 print('{:\*\>20}'.format(s)) # 右对齐,不足指定宽度部分用\*号填充 print('{:0\>20}'.format(s)) # 右对齐,指定0标志位填充 print('{:\>20}'.format(s)) # 右对齐,没指定填充值,用默认值空格填充 print('{:0\^30}'.format(s)) # 居中对齐,用+号填充不足部分 结果输出为: MMMMMMMMPYTMMMMMMMMM PYTHON min PYTHON mingrisoft.com mingrisoft.com \*\*\*\*\*\*mingrisoft.com 000000mingrisoft.com 锦囊8 指定转化 转换字段 conversion field 的取值有三种,前面要加 !: l s:传递参数之前先对参数调用 str() l r:传递参数之前先对参数调用 repr() l a:传递参数之前先对参数调用 ascii() 可以指定字符串的转化类型:其中 "!r" 对应 repr(); "!s" 对应 str(); "!a" 对应 ascii()。 print("repr() shows quotes: {!r}; str() doesn't: {!s}".format('mingri', 'soft')) print("joy is a cute {!s}".format("baby")) # !s 相当于对于参数调用str() print("joy is a cute {!r}".format("baby")) # !s 相当于对于参数调用str() print('I am {!s}!'.format('Bruce Lee 李小龙')) print('I am {!r}!'.format('Bruce Lee 李小龙')) print('I am {!a}!'.format('Bruce Lee 李小龙')) 结果输出为: repr() shows quotes: 'mingri'; str() doesn't: soft joy is a cute baby joy is a cute 'baby' I am Bruce Lee 李小龙! I am 'Bruce Lee 李小龙'! I am 'Bruce Lee \\u674e\\u5c0f\\u9f99'! 锦囊9 格式化日期月份 format()函数也可以对日期和时间进行格式化,格式化时可以通过日期和时间格式符号进行设置,常用python中时间日期格式化符号如表1所示。常用操作代码如下: **import**datetime now=datetime.datetime.now() print('{:%Y-%m-%d %H:%M:%S %A}'.format(now)) # 当前时间格式化为年月日+完整英文星期 print('{:%Y-%m-%d %H:%M:%S %a}'.format(now)) # 当前时间格式化为年月日+简写英文星期 # 中文年月日显示 print('{:%Y}'.format(now),'年','{:%m}'.format(now),'月','{:%d}'.format(now), '日') # 中文时间显示 print('{:%H}'.format(now),'时','{:%M}'.format(now),'分','{:%S}'.format(now), '秒') print('{:%Y-%m-%d %H:%M:%S %a}'.format(now)) # 当前时间格式化为年月日+简写英文星期 print('{:%Y-%m-%d}'.format(now)) # 当前时间格式化为标准年月日 print('{:%y-%m-%d}'.format(now)) # 当前时间格式化为短日期年月日 print('{:%Y\<%m\>%d}'.format(now)) # 当前时间格式化为长日期年月日, 间隔符为"\<"和"\>" print('{:%c}'.format(now)) # 本地对应的年月日星期表示 输出结果为: 2019-09-15 20:37:42 Sunday 2019-09-15 20:37:42 Sun 2019 年 09 月 15 日 20 时 37 分 42 秒 2019-09-15 20:37:42 Sun 2019-09-15 19-09-15 2019\<09\>15 Sun Sep 15 20:37:42 2019 **import**datetime now=datetime.datetime.now() print('{:%B}'.format(now)) # 本地完整的英文月份表示 print('现在是今年第{:%j}天'.format(now)) # 今天是一年中第几天 print('本周是今年第{:%U}周'.format(now)) # 本周是一年中第几周 print('{:%y%m%d}'.format(now)) # 无间隔符短年月日 print('{:%Y-%m}'.format(now)) # 长日期格式年月 print('{:%m-%d}'.format(now)) # 月日显示、 print('{:%m}'.format(now)) # 月份单独显示 print('{:%d}'.format(now)) # 日期单独显示 输出结果为: September 现在是今年第258天 本周是今年第37周 190915 2019-09 09-15 09 15 **import**datetime now=datetime.datetime.now() print('{:%H%M%S}'.format(now)) # 时分秒。无间隔符 print('{:%H:%M:%S}'.format(now)) # 标准时分秒 print('{:%H:%M:%S %I}'.format(now)) # 12小时制 时分秒 print('{:%H:%M}'.format(now)) # 时+分 print('{:%M%S}'.format(now)) # 时钟+分 print('{:%h}'.format(now)) # 只显示时钟点 print('{:%H:%M:%S %p}'.format(now)) # 日期显示按AM,PM显示 输出结果为: 205140 20:51:40 20:51:40 08 20:51 5140 Sep 20:51:40 PM **import**datetime now=datetime.datetime.now() print('{:%a}'.format(now)) # 英文星期简写 print('{:%A}'.format(now)) # 英文星期完整显示 week=\['星期日','星期一','星期二','星期三','星期四','星期五','星期六'\] print(week\[int('{:%w}'.format(now))\]) # 中文星期 输出结果为: Sun Sunday 星期日 **import**datetime dt = datetime.datetime(2019, 9, 9) dm=datetime.datetime(2019, 9, 9, 12, 50,20) # 将输入的日期按年月日和时间格式化,因时间没有输入,按0时处理 print('{:%Y-%m-%d %H:%M:%S}'.format(dt)) print('{:%Y-%m-%d}'.format(dt)) # 将输入的日期按年月日格式化 print('{:%Y-%m-%d %H:%M:%S}'.format(dm)) # 将输入的日期按年月日和时间格式化 输出结果为: 2019-09-09 00:00:00 2019-09-09 2019-09-09 12:50:20 **import**datetime now=datetime.datetime.now() print('{0:%Y%m%d}{1:03d}'.format(now,1)) # 年月日 +3位编号 print('{0:%Y%m%d}NO{1:03d}'.format(now,5)) # 年月日+NO+3位编号 print('{0:%d}NO{1:05d}'.format(now,8)) # 日期+NO+5位编号 print('{0:%H%M}NO{1:05d}'.format(now,8)) # 时钟+分 +NO+5位编号 **for** i **in**range(5): # 循环输出计算式 print('{0:%Y%m%d}NO{1:05d}'.format(now,i+1)) 输出结果为: 20190915001 20190915NO005 15NO00008 2135NO00008 20190915NO00001 20190915NO00002 20190915NO00003 20190915NO00004 20190915NO00005 锦囊10 数据对齐 在输出数据时,数据对齐的工整程度和数据之间的间距非常影响用户的阅读感受,如下面的2019年世界500强企业排行,如图11所示,数据间距过小,后面的数据也没有对齐,阅读感受不是很好。 ![](https://img-blog.csdnimg.cn/img_convert/ad3b8a0fece71820361fb022d8faa937.png) 图11 原数据阅读感较差 通过制表符"\\t",利用format()方法设置对齐字符串的宽度和对齐方式,可以很容易排列对齐数据,下面对世界500强企业进行对齐输出(数据保存在源文件目录下500.txt文件中),代码如下: **with** open("500.txt", 'r') **as**fp: lines=fp.readlines() **for** line **in**lines: list=line.strip().split(' ') str='' **for** item **in**list: str=str +'**\\t**{:10}'.format(item) print(str) 运行程序,输出结果如图12所示,从图中可以看到数据对齐比较工整,能较好地浏览数据。 ![](https://img-blog.csdnimg.cn/img_convert/df4f2b09a7ede379d3bfbbe495b728a3.jpeg) 图12 设置玩对齐的效果 对于常规的数据,使用通过制表符"\\t"和通过format()方法设置宽度和对齐方式就可以很好地实现对齐,但对于中文字段较多,字段较长的数据,如果设置文字宽度不合适,就很容出现文字不对齐的情况,如输出2018年全球大学排名前20名,代码如下: **with** open("dx.txt", 'r') **as**fp: lines=fp.readlines() **for** line **in**lines: list=line.strip().split(',') str='**\\t** {:0\>2}'.format(list\[0\])+'**\\t** {:\<6}'.format(list\[1\])+'**\\t** {0:\<16}'.format(list\[2\])+'**\\t**{:\<40}'.format(list\[3\]) print(str) 运行程序,输出效果如图13所示。 ![](https://img-blog.csdnimg.cn/img_convert/9cfe543efb9cfe2bba741bf97be45fc6.png) 图13 汉字字段较多时不对齐 从图13可以看到,输出的一些数据没有对齐,主要问题是utf-8中中文占用3个字节,GBK中占用了2个字节,英文字符占用一个字节,所以设置文字宽度时统一按英文文字占用一个1字节设置就会造成文字宽度不一致的情况。如果设置中文字段宽度时宽度不够时采用中文空格编码chr(12288)填充,就可以很好地解决这个问题,代码如下: **with** open("dx.txt", 'r') **as**fp: lines=fp.readlines() **for** line **in**lines: list=line.strip().split(',') str='**\\t** {0:0\>2}'.format(list\[0\])+'**\\t** {0:{1}\<5}'.format(list\[3\],chr(12288))+'**\\t** {0:{1}\<10}'.format(list\[1\],chr(12288))+'**\\t**{0:\<45}'.format(list\[2\]) print(str) 运行程序,输出效果如图14所示 ![](https://img-blog.csdnimg.cn/img_convert/cc2a0b90a06565d0116e3fca24f93274.jpeg) 图14 设置对齐的效果 锦囊11 生成数据编号 对数据进行编号,也是对字符串格式化操作的一种方式,设置填充字符(编号通常设置0),设置对齐方式时可以使用\<、\>和\^符号表示左对齐、右对齐和居中对齐,对齐填充的符号在"宽度"范围内输出时填充,如: print('{:0\>3}'.format(1)) print('{:0\>5}'.format('03')) print('a{:0\>6}'.format(111)) 输出结果为: 001 00003 a000111 要生成的编号通常比较复杂,如根据当天的日期建立编号,或者批量生成编号,或者将给定的批量数据中的数字转换成位数固定的编号,下面给出实现如上编号的实现方法: **import**datetime wx=datetime.datetime.now().date() now=datetime.datetime.now() print(str(wx)+'{:0\>3}'.format(1)) # 年月日 +3位编号 print('{:%Y%m%d}{:0\>3}'.format(now,1)) # 年月日 +3位编号 print('{:%Y%m%d}NO{:0\>5}'.format(now,5)) # 年月日+NO+3位编号 print('{:%Y}NO{:0\>5}'.format(now,5)) # 日期+NO+3位编号 print('{:%H%M}NO{:0\>3}'.format(now,5)) # # 时钟+分 +NO+3位编号 输出结果为: 2019-08-01001 20190801001 20190801NO00005 2019NO00005 1155NO005 20190801 NO001 01 NO001 1155 NO001 # 批量生成编号 for i in range(1,6): print('mr{:0\>3}'.format(i)) mr001 mr002 mr003 mr004 mr005 要实现嵌套编号,如A001-A005,B001-B005,C001-005的嵌套编号。代码如下: **for** i **in**range(65,69): **for** j **in**range(1,6): data=chr(i)+'{:0\>3}'.format(j)+' ' print(data,end='') print() 结果输出如下: ![](https://img-blog.csdnimg.cn/img_convert/fa6f3f06209e34f55ecec0e97811d12e.png) 锦囊12 format的索引序号作为函数变量 Format()的索引序号可以在Format()的位置参数或关键字参数中给定,也可以把索引序号作为函数变量,动态添加,如对输入的数字格式化为5位编号,编写函数mark,变量num作为索引序号,调用时直接赋值给num变量即可,实现代码如下: mark = "编号:{num:0\>5d}".format print(mark(num=3)) 输出结果为: 编号:00003 调用mark函数可以实现批量输出格式化的编号,如输出10个5位编号,编号从0001到00009,代码如下: mark = "编号:{num:0\>5d}".format **for** i **in**range(10): print(mark(num=i)) 输出结果为: 编号:00000 编号:00001 编号:00002 编号:00003 编号:00004 编号:00005 编号:00006 编号:00007 编号:00008 编号:00009 锦囊13 {}内嵌{} 格式化标签模板中的格式设置参数也可以通过str.Format()方法的位置参数或关键字参数给定,但必须放在{}里面,如通过{}内嵌{}将位置参数2的值设置位置参数1(3.1415926)的小数位数为2,则格式化模板为{0:\>.{1}f},其中{1}指定的是第2个位置参数2。代码如下: print('{0:\>.{1}f} '.format(3.1415926,2)) # {1}对应位置参数2 输出结果为: 3.14 通过{}内嵌{}在批量处理数据时非常有用,可以方便的设置变量,不用按个修改模板参数中的值,如输出9\*9的乘法口诀,可以设置输出口诀元素的宽度,如设置long为'1d'或'2d',把long设置为位置参数即可。代码如下: long='1d' **for** i **in**range(1,10): **for** j **in**range(1,10): print("{0:\<{3}}\*{1:\>{3}}={2:{3}}".format (i,j,i\*j,long),end=" ") print("") 运行程序,如图15所示,因为设置元素宽度为1个宽度,所以输出效果不是很整齐。修改第一行代码中的long='2d',运行程序,如图16所示,运行效果就比较整齐了。 ![](https://img-blog.csdnimg.cn/img_convert/6fc81c27c695e289b29b90fc1b3fbbe1.jpeg) 图15 long为'1d'的运行效果 ![](https://img-blog.csdnimg.cn/img_convert/957c1de6667e710aac8399cabcc1b833.jpeg) 图16 long为'2d'的运行效果 锦囊14 format变形 可以简化为f'xxxx'形式,在字符串前加f以达到格式化的目的,在{}里加入对象,如下面的代码: print('{0} {1}'.format('hello','world')) 可以简化为: a = 'hello' b = 'world' print(f'{a} {b}') 运行结果如下: hello world hello world ![](https://i-blog.csdnimg.cn/direct/6846356726f44527ade29fd8cde2f931.png)

相关推荐
2202_754421548 分钟前
生成MPSOC以及ZYNQ的启动文件BOOT.BIN的小软件
java·linux·开发语言
JH30739 分钟前
Oracle与MySQL中CONCAT()函数的使用差异
数据库·mysql·oracle
蓝染-惣右介11 分钟前
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
java·数据库·tomcat·mybatis
小林想被监督学习11 分钟前
idea怎么打开两个窗口,运行两个项目
java·ide·intellij-idea
冷心笑看丽美人12 分钟前
Spring框架特性及包下载(Java EE 学习笔记04)
数据库
HoneyMoose13 分钟前
IDEA 2024.3 版本更新主要功能介绍
java·ide·intellij-idea
我只会发热15 分钟前
Java SE 与 Java EE:基础与进阶的探索之旅
java·开发语言·java-ee
是老余16 分钟前
本地可运行,jar包运行错误【解决实例】:通过IDEA的maven package打包多模块项目
java·maven·intellij-idea·jar
crazy_wsp17 分钟前
IDEA怎么定位java类所用maven依赖版本及引用位置
java·maven·intellij-idea
.Ayang19 分钟前
tomcat 后台部署 war 包 getshell
java·计算机网络·安全·web安全·网络安全·tomcat·网络攻击模型