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

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于ADRC自抗扰算法的UAV飞行姿态控制系统simulink建模与仿真

目录 1.课题概述 2.系统仿真结果 3.核心程序与模型 4.系统原理简介 4.1 控制系统概述 4.2 ADRC基本框架 4.3 控制律设计 5.完整工程文件 1.课题概述 基于ADRC自抗扰算法的UAV飞行姿态控制系统simulink建模与仿真&#xff0c;分别对YAW&#xff0c;PITCH&#xff0c;ROL…

K-Means 算法详解

K-Means 是一种常用的无监督学习算法&#xff0c;广泛应用于数据聚类分析。本文将详细讲解 K-Means 算法的原理、步骤、公式以及 Python 实现&#xff0c;帮助你深入理解这一经典算法。 什么是 K-Means 算法&#xff1f; K-Means 算法是一种基于原型的聚类算法&#xff0c;其…

Linux分区以及磁盘管理

目录 一、磁盘 1.磁盘结构 1.1物理结构 1.2数据结构 2.1磁盘容量 2.2磁盘接口类型 2.磁盘分区的表示 3.MBR与磁盘分区表示 4.磁盘分区结构 二、文件系统 1、类型 三、命令 1.检测并确认新硬盘 2.创建系统文件(格式化) 2.1mkfs命令 2.2SWAP 3.挂载、卸载文件系统…

Simulink中三相PMSM配置及使用

1. 模块介绍 Simulink提供了专门用于电力系统仿真&#xff0c;包括电机的动态建模和控制的电机模型&#xff0c;其中&#xff0c;永磁同步电机模块 Permanent Magnet Synchronous Machine 支持实现三相或五相永磁同步电机模拟&#xff0c;电机绕组采用星型连接&#xff0c;在这…

【图像分类】Yolov8 完整教程 |分类 |计算机视觉

目标&#xff1a;用YOLOV8进行图像分类。 图像分类器。 学习资源&#xff1a;https://www.youtube.com/watch?vZ-65nqxUdl4 努力的小巴掌 记录计算机视觉学习道路上的所思所得。 1、文件结构化 划分数据集&#xff1a;train,val,test 知道怎么划分数据集很重要。 文件夹…

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

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

【系统架构设计师】计算机组成与体系结构 ③ ( 层次化存储结构 | 寄存器 | 高速缓存 | 内存 | 外存 )

文章目录 一、层次化存储结构1、层次化存储结构2、层次化存储结构 - 示例说明3、程序员可操作的部分 计算机 采用 分级存储结构 , 主要目的是 为了 解决 容量 / 价格 / 速度 之间的矛盾 ; 一、层次化存储结构 1、层次化存储结构 计算机 存储器 按照存储速度 由快到慢 进行排序 …

吐血推荐!3款视频生成工具,全部国产,都免费

AI视频大模型的爆发&#xff0c;让创作爆款视频不再是专业人士的能力。 今天二师兄给大家推荐3款免费的视频生成工具。 01 可灵 推荐指数 &#xff1a; 五颗星 先看效果 可灵大模型测试 可灵大模型是快手AI团队自主研发的视频生成大模型&#xff0c;具备强大的视频创作能力&a…

教程:在 Kubernetes 集群上部署 WordPress 网站

WordPress 是专为每个人设计的开源软件&#xff0c;强调创建网站、博客或应用程序的可访问性、性能、安全性和易用性。WordPress 是一个基于 PHP 的内容管理系统&#xff08;CMS&#xff09;&#xff0c;使用 MySQL 作为数据存储&#xff0c;目前很多网站、电商独立站、个人博客…

推荐系统三十六式学习笔记:原理篇.模型融合14|一网打尽协同过滤、矩阵分解和线性模型

目录 从特征组合说起FM模型1.原理2.模型训练3.预测阶段4.一网打尽其他模型5.FFM 总结 在上一篇文章中&#xff0c;我们讲到了使用逻辑回归和梯度提升决策树组合的模型融合办法&#xff0c;用于CTR预估&#xff0c;给这个组合起了个名字&#xff0c;叫“辑度组合”。这对组合中&…

个人支付系统实现

基础首页&#xff1a; 订单&#xff1a; 智能售卡系统 基于webmanworkerman开发 禁用函数检查 使用这个脚本检查是否有禁用函数。命令行运行curl -Ss https://www.workerman.net/check | php 如果有提示Function 函数名 may be disabled. Please check disable_functions in …

线程池FutureTask浅谈

一,概述 FuturnTask实现了Future与Runnable接口,笔者知道,ThreadPoolExecutor#submit可以传入Callable接口而非Runnable,区别点在于Callable可以返回值,而整个FuturnTask可以理解为Callable设计,用来优雅地异步获取执行结果,无需手动Condition去实现。 围绕此,需知道…

鸿蒙开发系统基础能力:【@ohos.wallpaper (壁纸)】

壁纸 说明&#xff1a; 本模块首批接口从API version 7开始支持。后续版本的新增接口&#xff0c;采用上角标单独标记接口的起始版本。 导入模块 import wallpaper from ohos.wallpaper;WallpaperType 定义壁纸类型。 系统能力: 以下各项对应的系统能力均为SystemCapability…

【项目实训】falsk后端连接数据库以及与前端vue进行通信

falsk连接数据库 我们整个项目采用vueflaskmysql的框架&#xff0c;之前已经搭建好了mysql数据库&#xff0c;现在要做的是使用flask连接到数据库并测试 安装flask 首先安装flask pip install flask 进行数据库连接 数据库连接需要使用到pymysql库以及flask库 连接数据库…

Linux-引导过程与服务控制

目录 一、Linux操作系统引导过程 1、引导过程总览 2、引导过程详解 2.1、开机自检&#xff08;BIOS&#xff09; 2.2、 MBR引导 2.3、GRUB菜单 2.4、加载内核(kernel) 2.5、init进程初始化 3、系统初始化进程 3.1、Systemd单元类型 3.2、运行级别所对应的 Systemd 目…

SherlockChain:基于高级AI实现的智能合约安全分析框架

关于SherlockChain SherlockChain是一款功能强大的智能合约安全分析框架&#xff0c;该工具整合了Slither工具&#xff08;一款针对智能合约的安全工具&#xff09;的功能&#xff0c;并引入了高级人工智能模型&#xff0c;旨在辅助广大研究人员针对Solidity、Vyper和Plutus智…

前端 Array.sort() 源码学习

源码地址 V8源码Array 710行开始为sort()相关 Array.sort()方法是那种排序呢&#xff1f; 去看源码主要是源于这个问题 // In-place QuickSort algorithm. // For short (length < 22) arrays, insertion sort is used for efficiency.源码中的第一句话就回答了我的问题…

Potato(土豆)一款轻量级的开源文本标注工具(二)

示例项目&#xff08;模版&#xff09; Potato 旨在提高数据标注的可复制性&#xff0c;并降低研究人员设置新标注任务的成本。因此&#xff0c;Potato 提供了一系列预定义的示例项目&#xff0c;并欢迎公众向项目中心贡献。如果您使用 Potato 进行了自己的标注工作&#xff0…

海思平台使用ITTP_Stream调试sensor

目录 相关资料1.ISP相关资料2.MIPI RX相关资料3.sensor资料4.MIPI标准 准备工作1.准备sensor驱动2.准备sample vio3.准备上位机和下位机程序 运行1.只运行HiPQTool1.1.板端运行1.2.PC端运行HiPQTool 2.使用ITTP_Stream2.1.板端运行2.2.打开上位机软件 相关资料 1.ISP相关资料 …

uniapp开发手机APP、H5网页、微信小程序、长列表插件

ml-list 插件地址&#xff1a;https://ext.dcloud.net.cn/plugin?id18928 ml-list介绍 1、ml-list 列表组件&#xff0c;包含基本列表样式、可扩展插槽机制、长列表性能优化、多端兼容。 2、ml-list 低代码列表&#xff0c;帮助使用者快速构建列表&#xff0c;简单配置&…