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<p,则采用小数计数法,并保留p-1-exp位小数,否则按小数计数法计数,并按p-1保留小数位数。

print('{:1g}'.format(0.000031415926))

print('{:.2g}'.format(0.000031415926))

print('{:.5G}'.format(0.000031415926))

print('{:.3n}'.format(0.000031415926))

print('{:1g}'.format(3.1415926))

print('{:.2g}'.format(3.1415926))

print('{:.5G}'.format(3.1415926))

print('{:.3n}'.format(3.1415926))

输出结果为:

3.14159e-05

3.1e-05

3.1416E-05

3.14e-05

3.14159

3.1

3.1416

3.14

*

    快用锦囊

锦囊1  格式转换

如果格式控制标记未提供,则默认为将其他格式数据格式化为字符型,如:

print('{}'.format(3.14))    # 使用format ()函数将浮点数转换成字符

import datetime

# 将日期格式化为字符

print('{}'.format(datetime.datetime.utcnow().strftime("%Y-%m-%d   %H:%M:%S")))

输出结果为:

3.14

2019-08-01   03:34:52

设置格式化为字符型值时,可以进行相应数据类型的格式化,字符串可以提供的参数为's' 。十进制整形提供的参数为'd' 和'n',二进制的参数为'b',八进制的参数为'o',十六进制小写的参数为 'x' ,十六进制大写的参数为 'X' ,ASC码的参数为'c',浮点数的参数为'f'。主要进制转换符号说明如下:

l  'b' - 二进制。将数字以2为基数进行输出。

l  'd' - 十进制整数。将数字以10为基数进行输出。

l  'o' - 八进制。将数字以8为基数进行输出。

l  'x' - 十六进制。将数字以16为基数进行输出,9以上的位数用小写字母。

十进制、十六进制、八进制、二进制的转换示例如下:

print('{:d}'.format(100))      # 转换成字符型、整形和浮点数

print('{:s}'.format('100'))      # 转换成字符型、整形和浮点数

print('{:c}'.format(97))               # 转换unicode成字符

print('{:d},{:f}'.format(100,12.2))      # 转换成整形和浮点数

print('{:8d},{:2d},{:2f}'.format(314,314,314))   # 转换成指定格式的十进制

print('{:c},{:c},{:c}'.format(65,33,8712))        # 转换成unicode字符

print('{:c}{:c}{:c}{:c}'.format(39321,26684,37324,25289))        # 转换unicode成字符

print('{:o},{:x},{:X}'.format(12,12,12))        # 将十进制转换成八进制和十六进制

输出结果为:

100

100

a

100,12.200000

     314,314,314.000000

A,!,∈

香格里拉

14,c,C

如果要将十六进制、八进制、二进制的数字转换为十进制数,一定要标注进制前缀,如"0x"“0o”“0b”,示例代码如下:

print('{:d}'.format(0X5A))    # 十六进制数5A转换成10进制数,0X代表十六进制数

print('{:8d}'.format(0B011101))   # 二进制数转换成10进制数,0B代表二进制数

print('{:d}'.format(0O34))    # 八进制数转换成10进制数,0O代表八进制数

print('{:08d}'.format(0O123456)) # 16制数123456转换成10进制数,不足用0填充

print('{:*>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 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 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所示,数据间距过小,后面的数据也没有对齐,阅读感受不是很好。

图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所示,从图中可以看到数据对齐比较工整,能较好地浏览数据。

图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所示。

图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所示

图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 in range(65,69):

    for in range(1,6):

        data=chr(i)+'{:0>3}'.format(j)+' '

        print(data,end='')

    print()

结果输出如下:

锦囊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 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 in range(1,10):

     for in range(1,10):

         print("{0:<{3}}*{1:>{3}}={2:{3}}".format (i,j,i*j,long),end=" ")

     print("")

运行程序,如图15所示,因为设置元素宽度为1个宽度,所以输出效果不是很整齐。修改第一行代码中的long='2d',运行程序,如图16所示,运行效果就比较整齐了。

图15  long为‘1d’的运行效果

图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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/750700.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

选择第三方软件测试机构做验收测试的好处简析

企事业单位在自行开发完软件系统或委托软件开发公司生产软件之后&#xff0c;有一个必经流程就是验收测试&#xff0c;以验证该产品是否符合用户需求、是否可以上线。为了客观评估所委托生产的软件质量&#xff0c;第三方软件测试机构往往成为企事业单位做验收测试的首选&#…

Bad owner or permissions on C:\\Users\\username/.ssh/config > 过程试图写入的管道不存在。

使用windows连接远程服务器出现Bad owner or permissions 错误 问题&#xff1a; 需要修复文件权限 SSH 配置文件应具有受限权限以防止未经授权的访问 确保只有用户对该.ssh/config文件具有读取权限 解决方案&#xff1a; 在windows下打开命令行&#xff0c;通过以下命令打开文…

PS使用批量脚本生成海报实践

前言 设计朋友有需求做一批邀请函&#xff0c;有几十个人名&#xff0c;需要把人名加到海报中&#xff0c;PS里一个一个添加人名很麻烦&#xff0c;于是来问我有没有什么办法能够批量去添加。 希望把人名加到红框区域内 尝试用ps的脚本进行处理 准备 PS(版本2021&#xff0c;…

HTML静态网页成品作业(HTML+CSS)——企业摄影网介绍网页(3个页面)

&#x1f389;不定期分享源码&#xff0c;关注不丢失哦 文章目录 一、作品介绍二、作品演示三、代码目录四、网站代码HTML部分代码 五、源码获取 一、作品介绍 &#x1f3f7;️本套采用HTMLCSS&#xff0c;未使用Javacsript代码&#xff0c;共有3个页面。 二、作品演示 三、代…

Micro-ROS是什么?

Micro-ROS是ROS&#xff08;Robot Operating System&#xff0c;机器人操作系统&#xff09;生态系统的一个重要组成部分&#xff0c;专为微控制器&#xff08;Microcontrollers&#xff09;设计的轻量级ROS版本。它的目标是在资源有限的嵌入式平台上实现ROS 2的功能&#xff0…

各省药品集中采购平台-地方药品集采分析数据库

国家第十批药品集中采购的启动时间暂未明确&#xff0c;但即将到来&#xff0c;在5月&#xff0c;国家医保局发布了《关于加强区域协同做好2024年医药集中采购提质扩面的通知》&#xff0c;其中明确指出将“开展新批次国家组织药品和医用耗材集中带量采购&#xff0c;对协议期满…

转转游戏MQ重构:思考与心得之旅

文章目录 1 背景1.1 起始之由1.2 重构前现状1.3 问题分析 2 重构2.1 目标2.2 制定方案2.2.1 架构设计2.2.2 实施计划2.2.3 测试计划 2.3 部分细节设计 3. 总结 1 背景 游戏业务自 2017 年启航&#xff0c;至今已近乎走过七个春秋&#xff0c;历经漫长岁月的发展&#xff0c;不…

应用图扑 HT for Web 搭建拓扑关系图

拓扑结构在计算机网络设计和通信领域中非常重要&#xff0c;因为它描述了网络中的设备&#xff08;即“点”&#xff09;如何相互连接&#xff08;即通过“线”&#xff09;。这种结构不仅涉及物理布局&#xff0c;即物理拓扑&#xff0c;还可以涉及逻辑或虚拟的连接方式&#…

C++ ─── vector模拟实现的扩容拷贝问题

扩容拷贝问题 源代码使用memcpy拷贝&#xff0c;在使用vector<int>存储内置类型时没有问题&#xff0c; 但是如果存储的是含有指针的类型&#xff0c;如string&#xff0c;就会发生浅拷贝问题 //3、容量相关void reserve(size_t n){if (n > capacity()){size_t old_si…

数字水产养殖中的鱼类追踪、计数和行为分析技术

随着全球人口增长和生态环境退化&#xff0c;传统捕捞已无法满足人类对水产品的需求&#xff0c;水产养殖成为主要的鱼类来源。数字水产养殖利用先进技术和数据驱动方法&#xff0c;对提高生产效率、改善鱼类福利和资源管理具有显著优势。 1 数字水产养殖的重要性 1.1 提高生…

Java web应用性能分析之【prometheus监控指标体系】

Java web应用性能分析之【系统监控工具prometheus】_javaweb服务器性能监控工具-CSDN博客 Java web应用性能分析之【prometheusGrafana监控springboot服务和服务器监控】_grafana 导入 prometheus-CSDN博客 因为篇幅原因&#xff0c;前面没有详细说明Prometheus的监控指标&…

小红书2024LLM论文分享

2024小红书大模型论文分享 BatchEval基于LLM评估LLM生成文本的质量 ACL2024 https://ypw0102.github.io/ 如果文本评价需要多个维度&#xff0c;需要调整BatchEval么&#xff1f; 目前是完整流程走一遍的&#xff0c;因此没有具体考虑细粒度。 评测连续的数据域&#xff0c;S…

使用飞书多维表格实现推送邮件

一、为什么用飞书&#xff1f; 在当今竞争激烈的商业环境中&#xff0c;选择一款高效、智能的办公工具至关重要。了解飞书的朋友应该都知道&#xff0c;飞书的集成能力是很强大的&#xff0c;能够与各种主流的办公软件无缝衔接&#xff0c;实现数据交互&#xff0c;提升工作效…

VAE-pytorch代码

import osimport torch import torch.nn as nn import torch.nn.functional as F from torch.utils.data import DataLoaderfrom torchvision import transforms, datasets from torchvision.utils import save_imagefrom tqdm import tqdmclass VAE(nn.Module): # 定义VAE模型…

基于盲信号处理的声音分离-基于改进的信息最大化的ICA算法

基于信息最大化的ICA算法的主要依据是使输入端与输出端的互信息达到最大&#xff0c;且输出各个分量之间的相关性最小化&#xff0c;即输出各个分量之间互信息量最小化&#xff0c;其算法的系统框图如图所示。 基于信息最大化的ICA算法的主要依据是使输入端与输出端的互信息达到…

java基于ssm+jsp 弹幕视频网站

1前台首页功能模块 弹幕视频网站&#xff0c;在弹幕视频网站可以查看首页、视频信息、商品信息、论坛信息、我的、跳转到后台、购物车、客服等内容&#xff0c;如图1所示。 图1前台首页界面图 登录&#xff0c;通过登录填写账号、密码等信息进行登录操作&#xff0c;如图2所示…

Sparse4D v1

Sparse4D: Multi-view 3D Object Detection with Sparse Spatial-Temporal Fusion 单位&#xff1a;地平线 GitHub&#xff1a;https://github.com/HorizonRobotics/Sparse4D 论文&#xff1a;https://arxiv.org/abs/2211.10581 时间&#xff1a;2022-11 找博主项目讨论方…

【MotionCap】conda 链接缺失的cuda库

conda 安装的环境不知道为啥python 环境里的 一些cuda库是空的要自己链接过去。ln 前面是已有的,后面是要新创建的 ln -s <path to the file/folder to be linked> cuda 有安装 libcublas 已经在cuda中 (base) zhangbin@ubuntu-server:~/miniconda3/envs/ai-mocap/lib/…

ARM芯片架构(RTOS)

前言&#xff1a;笔记韦东山老师的rtos教程&#xff0c;连接放在最后 #ARM介绍 arm芯片属于精简指令集risc&#xff0c;所用的指令比较简单&#xff0c;ARM架构是一种精简指令集&#xff08;RISC&#xff09;架构&#xff0c;广泛应用于移动设备、嵌入式系统、物联网等领域。AR…

40.设计HOOK引擎的好处

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 上一个内容&#xff1a;39.右键弹出菜单管理游戏列表 以 39.右键弹出菜单管理游戏列表 它的代码为基础进行修改 效果图&#xff1a; 实现步骤&#xff1a; 首…