全网最细 Python 格式化输出用法讲解(推荐)

一、使用 print() 函数

在 Python 中,print() 函数支持格式化输出,与 C 语言的 printf 类似。

1. 格式化输出字符串和整数

【示例1】输出字符串 AmoXiang,并计算、输出它的字符长度

str1 = "%s.length = %d" % ("AmoXiang", len("AmoXiang"))
print(str1) # 输出AmoXiang.length = 8

% 在字符串中表示格式化操作符,它后面必须附加一个格式化符号,具体说明如下表所示。

%()元组可以包含一个或多个值,如变量或表达式,用来向字符串中%操作符传递值,元组包含元素数量、顺序都必须与字符串中%操作符一一对应,否则将抛出异常。%()元组必须位于字符串的后面,否则无效。如果字符串中只包含一个%操作符,那么也可以直接传递值。例如:

str1 = "AmoXiang.length = %d" % len("AmoXiang")
print(str1) # 输出AmoXiang.length = 8

2. 格式化输出不同进制数

【示例2】使用 print() 函数把数字输出为十六进制、十进制、八进制格式的字符串。

num = 123
# 输出:Hex = 7b Dec = 123 Oct=173
print("Hex = %x Dec = %d Oct=%o" % (num, num, num))

补充:整数类型包括十进制整数、八进制整数、十六进制整数和二进制整数。

十进制的整数不能以 0 开头。八进制整数由 0~7 组成,逢八进一,以 0o 或 0O 开头,例如:0o23十六进制整数由 0~9 以及 a~f 组成,逢十六进一,以 0x 或 0X 开头。例如:0x23二进制整数由 0 和 1组成,逢二进一,以 0b 或 0B 开头。例如:0b101关于进制这个知识点不懂的读者可以点击 进制转换 学习

3. 格式化输出浮点数

【示例3】把数字输出为不同格式的浮点数字符串。

PI = 3.141592653
print("pi1 = %10.3f" % PI) # 总宽度为10,小数位精度为3
print("pi2 = %.*f" % (3, PI)) # *表示从后面的元组中读取3,定义精度
print("pi3 = %010.3f" % PI) # 用0填充空白
print("pi4 = %-10.3f" % PI) # 左对齐,总宽度10个字符,小数位精度为3
print("pi5 = %+f" % PI) # 在浮点数前面显示正号

程序运行结果如下:

在格式化输出数字或字符串时,可以附加辅助指令来完善格式化操作。具体说明如下表所示:

二、使用 str.format() 方法

% 操作符是传统格式化输出的基本方法,从 Python 2.6 版本开始,为字符串数据新增了一种格式化方法 str.format(),它通过 {} 操作符和 : 辅助指令来代替 % 操作符。
【示例1】通过位置索引值

print('{0} {1}'.format('Python', 3.7)) # Python 3.7
print('{} {}'.format('Python', 3.7)) # Python 3.7
print('{1} {0} {1}'.format('Python', 3.7)) # 3.7 Python 3.7

在字符串中可以使用 {} 作为格式化操作符。与 % 操作符不同的是,{} 操作符可以通过包含的位置值自定义引用值的位置,也可以重复引用。
【示例2】通过关键字索引值

# 输出:Amo年龄是18岁。
print('{name}年龄是{age}岁。'.format(age=18, name="Amo"))

【示例3】通过下标进行索引

L = ["Jason", 30]
# 输出:Jason年龄是30岁。
print('{0[0]}年龄是{0[1]}岁。'.format(L))

通过使用 format() 函数这种便捷的 映射 方式,列表和元组可以 打散 成普通参数传递给 format() 方法,字典可以打散成关键字参数给方法。format() 方法包含丰富的格式限定符,附带在 {} 操作符中 : 符号的后面。

1. 填充与对齐

: 符号后面可以附带填充的字符,默认为空格, ^、<、> 分别表示居中、左对齐、右对齐,后面附带宽度限定值。

【示例4】下面示例设计输出 8 位字符,并分别设置不同的填充字符和值对齐方式。

print('{:>8}'.format('1')) # 总宽度为8,右对齐,默认空格填充
print('{:0>8}'.format('1')) # 总宽度为8,右对齐,使用0填充
print('{:a<8}'.format('1')) # 总宽度为8,左对齐,使用a填充

程序运行结果如下:

2. 精度与类型f

【示例5】f 与 float 类型数据配合使用

print('{:.2f}'.format(3.141592653)) # 输出结果:3.14

其中 .2f 表示小数点后面的精度为 2,f 表示浮点数输出。

3. 进制数字输出

【示例6】使用b、d、o、x 分别输出二进制、十进制、八进制、十六进制数字。

num = 100
print('{:b}'.format(num)) # 1100100
print('{:d}'.format(num)) # 100
print('{:o}'.format(num)) # 144
print('{:x}'.format(num)) # 64

4. 千位分隔输出

【示例7】使用逗号(,)输出金额的千分位分隔符。

print('{:,}'.format(1234567890)) # 1,234,567,890

三、详解 format() 函数

format()函数可以对数据进行格式化处理操作。语法格式如下:

format_spec为格式化解释。当参数 format_spec 为空时,等同于函数 str(value) 的方式。value 为要转换的数据。format_ spec 可以设置非常复杂的格式转换参数,生成比较完备的数据格式处理模板。format_spec 的编写方式如下形式:

format_spec ::= [[fill]align][sign][#][0][width][,][.precision][type]

format_spec 格式控制符可以分为文字对齐、填充值、标志设置、格式化、类型转换、千位符(数字分组)等主要应用。细化分类说明如下图所示:

参数说明:
(1) fill(填充值):此处可以填写任何字符,通常与align、width一起使用,实现指定位数字符填充,通常格式如图1.2所示,填充效果及位置如图1.3所示。

通常用 0、*、#、@ 等进行填充。如果不写填充值,则使用默认填充值,默认填充值为空格。代码如下:

# 81@@@@@@@@
print(format(81, '@<10')) # 用@符号填充,宽度为10个空格
# @@@@@@@@81
print(format(81, '@>10')) # 用@符号填充,宽度为10个空格

(2) align(对齐方式):指在 width(数字宽度) 内输出时的对齐方式,分别使用 <、>、^、= 4个符号表示左对齐、右对齐、居中对齐和数字填充(只用于数字,在符号后进行补齐)。
(3) width(数字宽度):指设定输出字符宽度,如果数据的实际位数比 width 指定宽度值大,则使用数据实际的长度。如果该值的实际位数小于指定宽度,则位数将设定的 fill 值填充或设定的 0 值填充,如果没有设置填充值,则用空格填充。

s = "PYTHON"
print(format(s, '10')) # 没有标志符,如果是字符串则默认左对齐,不足宽度部分默认用空格填充
print(format(13.14, '10')) # 没有标志符,如果是数字则默认右对齐,不足宽度部分默认用空格填充
print(format(s, '0>10')) # 右对齐,不足指定宽度部分用0填充
print(format(s, '>04')) # 右对齐,因字符实际宽度大于指定宽度4,不用填充
print(format(s, '*>10')) # 右对齐,不足部分用"*"填充
print(format(s, '>010')) # 右对齐,不足部分用0填充
print(format(s, '>10')) # 右对齐,默认用空格填充
print(format(s, '<10')) # 左对齐,默认用空格填充
print(format(s, '<010')) # 左对齐,不足部分用0填充
print(format(s, '@^10')) # 中间对齐,不足部分用'@'填充,宽度为10个空格
print(format(13.14, '0<10')) # 左对齐,不足部分用0填充
print(format(13.14, '@^10')) # 中间对齐,不足部分用@填充
print(format(13.14, '0>10')) # 右对齐,不足部分用0填充
print(format(-13.14, '0=10')) # 右对齐,符号后面不足部分用0填充

程序运行结果如下:

(4) precision(精度):精度由小数点 . 开头。对于浮点数,精度表示小数部分输出的有效位数。对于字符串,精度表示输出的最大长度。precision(精度) 通常和 type(类型) 配合起来使用。
(5) type(类型):表示输出字符串、整数和浮点数类型的格式规则,默认为字符型 s。对于整数类型,输出格式包括 7 种:

b:输出整数的二进制方式。c:输出整数对应的 Unicode 字符。d:输出整数的十进制方式。n:输出整数的十进制方式。o:输出整数的八进制方式。x:输出整数的小写十六进制方式。当值为整数时和 d 类似,值为浮点数时和 g 类似。不同之处在于 n 会使用当前区域设置来插入适当数字分隔字符。X:输出整数的大写十六进制方式。

对于浮点数类型,输出格式包括 7 种:

e:输出浮点数对应的小写字母 e 的指数形式。E:输出浮点数对应的大写字母 E 的指数形式。f:输出浮点数的浮点表示形式,默认保留 6 位小数。F:输出浮点数的浮点表示形式,默认保留 6 位小数,无穷大转换成大写字母 INF。g:自动调整将整数、浮点数转换成浮点型或科学记数法表示(超过 6 位数用科学记数法),并将其格式化到指定位置(如果是科学计数则是 e)。G:自动调整将整数、浮点数转换成浮点型或科学记数法表示(超过 6 位数用科学记数法),并将其格式化到指定位置(如果是科学计数则是 E)。%:输出浮点数的百分形式。 运用一:格式转换

使用 format() 函数可以转换格式。如果 format() 函数的参数format_spec 未提供,则默认为将其他格式数据格式化为字符型,和调用 str(value) 效果相同。如:

import datetime

# 使用format()函数将浮点数转换成字符,结果为:'3.14'
print(format(3.14))
# 使用str()函数将浮点数转换成字符,结果为:'3.14'
print(str(3.14))
# 将日期格式化为字符,结果为:'2021-01-17 05:25:02'
print(format(datetime.datetime.utcnow().strftime("%Y-%m-%d %H:%M:%S")))

设置参数 format_spec 的值,可以进行相应数据类型的格式化,字符串可以提供的参数为 s。十进制整型提供的参数为 d 和 n,二进制的参数为 b,八进制的参数为 o,十六进制小写的参数为 x,十六进制大写的参数为 X,ASIIC 码的参数为 c,浮点数的参数为 f。以上格式化后的数据类型都为字符型,举例如下:

print(format(12.2, 'f')) # 转换成浮点数,默认为小数保留6位,输出:12.200000
print(format(12, 'd')) # 转换成十进制,输出:12
print(format(13)) # 不带参数默认为十进制,输出:13
print(format(13, 'n')) # 转换成十进制数,输出:13
print(format(13, 'b')) # 转换成二进制,输出:1101
print(format(65, 'c')) # 转换Unicode成字符,输出:A
print(format(97, 'c')) # 转换Unicode成字符,输出:a
print(format(8750, 'c')) # 转换Unicode成字符,输出:∮
print(format(12, 'o')) # 转换成八进制,输出:14
print(format(12, 'x')) # 转换成十六进制小写字母表示,输出:c
print(format(12, 'X')) # 转换成十六进制大写字母表示,输出:C

运用二:生成数据编号

利用 format() 函数实现数据编号。对数据进行编号,也是对字符串格式化操作的一种方式,使用 format() 函数可以对字符串进行格式化编号。只需设置填充字符(编号通常设置 0),设置对齐方式时可以使用 <、> 和 ^ 符号表示左对齐、右对齐和居中对齐,对齐填充的符号在 宽度 范围内输出时填充即可。对数字 1 进行 3 位编号,右对齐,需要设置 format() 函数的填充字符为 0,对齐方式为右对齐,宽度为 3。具体代码为:

print(format(1, '0>3')) # 输出:001
print(format(1, '>03')) # 输出:001
print(format(15, '0>5')) # 输出:00015

要生成的编号通常比较复杂,如根据当天的日期建立编号,或者批量生成编号,或者将给定的批量数据中的数字转换成位数固定的编号,下面给出实现编号的代码:

import datetime

# 时间+编号
wx = datetime.datetime.now().date()
now = datetime.datetime.now()
print(str(wx), format(1, '0>3')) # 年-月-日 +3位编号,输出:2021-01-17 001
print(format(now, '%Y-%m-%d'), format(1, '0>3')) # 年-月-日 +3位编号,输出:2021-01-17 001
print(format(now, '%Y%m%d'), 'NO' + format(1, '0>3')) # 年-月-日+NO+3位编号,输出:20210117 NO001
print(format(now, '%d'), 'NO' + format(1, '0>3')) # 日期 +NO+3位编号,输出:17 NO001
print(format(now, '%H%M'), 'NO' + format(1, '0>3')) # 时-+分 +NO+3位编号,输出:1411 NO001

批量生成编号:

# 批量生成编号
for i in range(1, 6):
 print(format(i, '0>2'))

程序运行结果如下:

# 格式化列表编号
# 对已有非编号数字进行格式化编号
nba = {1: '伦纳德', 2: '哈登', 3: '乔治'}
for key, value in nba.items():
 print(format(key, '0>3'), value)

程序运行结果如下:

要实现嵌套编号,如A001-A005、B001-B005、C001-005 的嵌套编号,代码如下:

for i in range(65, 69):
 for j in range(1, 6):
 data = chr(i) + format(j, '0>3') + ' '
 print(data, end='')
 print()

程序运行结果如下:

运用三:格式化十进制整数

对于不同的类型数据,format() 函数的参数 format_spec 提供的值都不一样,对于十进制整数,整型数值可以提供的参数有d、n。具体如下:

运用四:格

print(format(81, '8d')) # 8位整数显示,不足部分整数前用空格填充
print(format(81, '+d')) # 格式化为带符号整数显示数据
print(format(-81, '8d')) # 格式化为8位带符号整数显示,补位空格放到符号前
print(format(81, '=8d')) # 格式化为8位正整数,用空格补位
print(format(-81, '=8d')) # 格式化为8位负整数,不足部分在负号后填充
print(format(81, '+8d')) # 格式化为8位正整数,不足部分在符号前填充
print(format(-81, '8d')) # 格式化为8位负整数,不足部分在符号前填充

print(format(81, '>10')) # 右对齐,宽度为10个字符
print(format(81, '<10')) # 左对齐,宽度为10个字符
print(format(81, '010')) # 用0填充空格,宽度为10个字符
print(format(81, '@<10')) # 用“@”填充空格,宽度为10个字符
print(format(81, '@>10')) # 用“@”填充空格,宽度为10个字符
print(format(+81, '=10')) # 右对齐,宽度为10个字符
print(format(81, '0^10')) # 用0填充空格,宽度为10个字符

s = 125
print(format(s, '0>10')) # 右对齐,不足指定宽度部分用0填充
print(format(s, '>04')) # 右对齐,不足指定宽度部分用0填充
print(format(s, '*>10')) # 右对齐,不足指定宽度部分用“*”填充
print(format(s, '>010')) # 右对齐,指定0标志位填充
print(format(s, '>10')) # 右对齐,没指定填充值,用默认值空格填充
print(format(s, '+^30')) # 居中对齐,用“+”填充不足部分
print(format(s, '*<8')) # 右对齐,不足指定宽度部分用“*”填充
print(format(s, '08')) # 右对齐,指定0标志位填充

式化浮点数

对于浮点数类型,可以提供的参数有e、E、f、F、g、G、n、%、None 等。
用 f 表示浮点类型,可以在其前边加上精度控制,用于控制输出宽度。如果输出位数大于宽度,就按实际位数输出。还可以为浮点数指定符号,+表示在正数前显示正号+。- 表示在负数前显示负号 - (- 与什么都不加({:f})时一致)。空格表示在正数前加空格,在负数前加 -,.3f 表示浮点数的精度为 3(小数位保留3位)。

print(format(628, '.1f')) # 格式化为保留1位小数的浮点数,输出:628.0
print(format(628, '.2f')) # 格式化为保留2位小数的浮点数,输出:628.00
print(format(3.14159, '.1f')) # 格式化为保留1位小数的浮点数,输出:3.1
print(format(3.14159, '.2f')) # 格式化为保留2位小数的浮点数,输出:3.14
print(format(3.14159, '.5f')) # 格式化为保留5位小数的浮点数,输出:3.14159
print(format(-3.14159, '.3f')) # 格式化为保留3位小数的浮点数,输出:-3.142
print(format(3.1415926535898, 'f')) # 默认精度保留6位小数,输出:3.141593
# 默认精度保留6位小数,不足部分用空格填充,输出:3.141590
print(format(3.14159, 'f'))

print(format(3.14159, '+.3f')) # 格式化为保留3位小数带符号的浮点数
print(format(3.14159, '>8.2f')) # 右对齐,保留2位小数
print(format(3.14159, '<10.2f')) # 左对齐,宽度为10,保留2位小数,不足部分用空格填充
print(format(3.14159, '<.3f')) # 左对齐,保留3位小数
print(format(3.14159, '@>10.3f')) # 右对齐,用“@”填充不足位置
print(format(-3.14159, '=10.2f')) # 格式化为保留2位小数的10位数,默认用空格填充
print(format(-3.14159, '0=10.2f')) # 格式化为保留2位小数的10位数,空格用0填充
print(format(3.14159, '0^10.2f')) # 保留2位小数的10位数,居中显示,空格用0填充

运用五:格式化百分数

在格式化解释中单独或者在精度之后添加 % 号,可以实现用百分数显示浮点数,如:

print(format(0.161896, '%')) # 将小数格式化成百分数,输出:16.189600%
print(format(0.161896, '.2%')) # 格式化为保留2位小数的百分数,输出:16.19%
print(format(0.0238912, '.6%')) # 格式化为保留6位小数的百分数,输出:2.389120%
print(format(2 / 16, '.2%')) # 格式化为保留2位小数的百分数,输出:12.50%
print(format(3.1415926, '.1%')) # 格式化为保留1位小数的百分数,输出:314.2%
print(format(0.161896, '.0%')) # 格式化为保留整数的百分数,输出:16%
print(format(0.0238912, '8.6%')) # 格式化为保留6位小数的八位百分数,输出:2.389120%
print(format(0.0238912, '>8.3%')) # 格式化为保留3位小数的八位百分数,输出:2.389%

运用六:格式化科学记数法

如果要将浮点数采用科学记数法表示,可以在格式化模板中使用 e 和 E 或者 g 和 G。e 为通用的幂符号,用科学记数法打印数字,用 e 表示幂。使用 g 时,将数值以 fixed-point 格式输出。当数值特别大的时候,用幂形式输出。

#####e和E
print(format(3141592653589, 'e')) # 科学记数法,默认保留6位小数,输出:3.141593e+12
print(format(3.14, 'e')) # 科学记数法,默认保留6位小数,输出:3.140000e+00
print(format(3.14, '0.4e')) # 科学记数法,默认保留4位小数,输出:3.1400e+00
print(format(3141592653589, '0.2e')) # 科学记数法,保留2位小数,输出:3.14e+12
print(format(3141592653589, '0.2E')) # 科学记数法,保留2位小数,采用大写E表示,输出:3.14E+12
#####g和G
print(format(3.14e+1000000, 'F')) # 无穷大转换成大写字母,输出:INF
print(format(3141592653589, 'g')) # 科学记数法,保留2位小数,输出:3.14159e+12
print(format(314, 'g')) # 科学记数法,保留2位小数,输出:314
print(format(3141592653589, '0.2g')) # 科学记数法,保留2位有效数字,采用小写e表示,输出:3.1e+12
print(format(3141592653589, 'G')) # 科学记数法,保留5位小数,采用大写E表示,输出:3.14159E+12
print(format(3.14e+1000000, 'g')) # 小数点计数法,无穷大转换成小写字母,输出:inf

运用七:格式化金额

format() 函数还能用来作金额的千位分隔符。如果要实现金额前面带上相关货币的符号形式的功能,需要在该函数前面手动加上相应货币符号。如:

print('$' + format(1201398.2315, '.2f')) # 添加美元符号,小数保留2位
print(chr(36) + format(1201398.2315, '.2f')) # ASCII码添加美元符号,小数保留2位
print('¥' + format(78088888, ',')) # 添加人民币符号,用千位分隔符区分金额
print('£' + format(7908.2315, '.2f')) # 添加英镑符号,用千位分隔符进行区分
print('€' + format(7908.2315, ',.2f')) # 添加欧元符号,保留两位小数,千位分隔
print(chr(0x20ac) + format(1201398.2315, ',f')) # 使用十六进制编码添加欧元符号

程序运行结果如下:

运用八:格式化字符

格式化字符主要包括截取字符串,字符串对齐方式显示,填充字符串等,代码如下:

print(format('PYTHON', 'M^20.3')) # 截取3个字符,宽度为20居中,不足用M填充
print(format("PYTHON", '10')) # 默认居左显示,不足部分用空格填充
print(format('blog.csdn.net', '.3')) # 截取3个字符,默认居左显示
print(format("PYTHON", '>10')) # 居右显示,不足部分用空格填充
s = 'blog.csdn.net'
print(format(s, '0>20')) # 右对齐,不足指定宽度部分用0填充
print(format(s, '>4')) # 右对齐,因字符实际宽度大于指定宽度4,不用填充
print(format(s, '*>20')) # 右对齐,不足指定宽度部分用*填充
print(format(s, '>020')) # 右对齐,指定0标志位填充
print(format(s, '>20')) # 右对齐,没指定填充值,用默认值空格填充
print(format(s, '+^30')) # 居中对齐,用+填充不足部分

程序运行结果如下:

运用九:进制转换

进制转换主要是进行十进制、十六进制、八进制、二进制的转换,如果是十六进制、八进制、二进制数,转换前最好保留进制前缀,如 Ox/0o/0b,这样可以保证转换的准确性。主要进制转换符号说明如下:

b:二进制。将数字以 2 为基数进行输出。d:十进制整数。将数字以 10 为基数进行输出。o:八进制。将数字以 8 为基数进行输出。x:十六进制。将数字 以16 为基数进行输出,9 以上的数字用小写字母。

十进制、十六进制、八进制、二进制的转换代码如下:

print(format(77)) # 格式参数为空,默认为十进制
print(format(77, 'd')) # 原来是十进制数,转换后为原值
print(format(-77, 'd')) # 原来是十进制数,转换后为原值
print(format(77, '8d')) # 转换为8位十进制数,空余部分用空格填充
print(format(-77, '8d')) # 转换为8位十进制数,负数在负号前填充空余部分空格
print(format(77, '+8d')) # 转换为8位带符号十进制数,在符号前填充空余部分空格
print(format(-77, '08d')) # 转换为8位十进制数,负数在负号前填充空余部分空格
print(format(77, '+08d')) # 转换为8位带符号十进制数,在符号前填充空余部分空格
print(format(-77, '#8d')) # 转换为8位十进制数,加进制标志
print(format(-77, '=8d')) # 转换为8位十进制数,空余部分填充空格
print(format(+77, '=8d')) # 转换为8位十进制数,空余部分填充空格
print(format(+77, '*=8d')) # 转换为8位十进制数,空余部分填充*
print(format(+77, '*=+8d')) # 转换为8位带符号十进制数,符号与数据之间填充*
print(format(-77, '#=8d')) # 转换为8位十进制数,在符号与空余部分填充#
print(format(+77, '*<8d')) # 转换为8位十进制数,左对齐,空余部分填充*
print(format(-77, '#>8d')) # 转换为8位十进制数,右对齐,空余部分填充#
print(format(0X5A, 'd')) # 十六进制数5A转换成十进制数,0X代表十六进制数
print(format(0B011101, '+8d')) # 二进制数011101转换成十进制数,0B代表二进制数
print(format(0O34, 'd')) # 八进制数34转换成十进制数,0O代表八进制数
print(format(0O123456, '08d')) # 十六制数123456转换成十进制数,不足用0填充
print(format(+0X1234, '*>8d')) # 十六进制数1234转换成十进制数,右对齐,不足用*

对于带有进制前缀的数,如 0x、0o、0b,可以直接在后面加上 x、o、b 进行删除。

print(format(0X5A, 'x')) # 去除十六进制数的前缀,输出:5a
print(format(0B011101, 'b')) # 去除二进制数的前缀,输出:11101
print(format(0O34, 'o')) # 去除八进制数的前缀,输出:34

运用十:格式化日期和时间

format() 函数也可以对日期和时间进行格式化,格式化时可以通过日期和时间格式符号进行设置,Python 中常用的时间日期格式化符号如表 1.1 所示。

常用操作代码如下:

import datetime

now = datetime.datetime.now()
print(format(now, '%Y-%m-%d %H:%M:%S %A')) # 当前时间格式化为年-月-日+完整英文星期
print(format(now, '%Y-%m-%d %H:%M:%S %a')) # 当前时间格式化为年-月-日+简写英文星期
# 中文年-月-日显示
print(format(now, '%Y'), '年', format(now, '%m'), '月', format(now, '%d'), '日')
# 中文时间显示
print(format(now, '%H'), '年', format(now, '%M'), '分', format(now, '%S'), '秒')
print(format(now, '%Y-%m-%d %H:%M:%S %a')) # 当前时间格式化为年-月-日+简写英文星期
print(format(now, '%Y-%m-%d')) # 当前时间格式化为标准年-月-日
print(format(now, '%y-%m-%d')) # 当前时间格式化为短日期年-月-日
print(format(now, '%Y<%m>%d')) # 当前时间格式化为长日期年-月-日,间隔符为“<”和“>”
print(format(now, '%c')) # 本地对应的年-月-日星期表示

print(format(now, '%B')) # 本地完整的月份表示,输出:May
print('现在是今年第', format(now, '%j'), '天') # 今天是一年中第几天,输出:现在是今年第 017 天
print('本周是今年第', format(now, '%U'), '周') # 本周是一年中第几周,输出:本周是今年第 02 周
print(format(now, '%y%m%d')) # 无间隔符短日期格式年月日,输出:210117
print(format(now, '%Y-%m')) # 长日期格式年-月,输出:2021-01
print(format(now, '%m-%d')) # 月-日显示,输出:01-17
print(format(now, '%m')) # 月份单独显示,输出:01
print(format(now, '%d')) # 日期单独显示,输出:17

print(format(now, '%H%M%S')) # 无间隔符,输出:133536
print(format(now, '%H:%M:%S')) # 标准时-分-秒,输出:13:35:36
print(format(now, '%I:%M:%S %I')) # 12小时制时-分-秒,输出:01:35:36 01
print(format(now, '%H:%M')) # 时+分,输出:13:35
print(format(now, '%M%S')) # 分+秒,输出:3536
print(format(now, '%H')) # 只显示小时,输出:13
print(format(now, '%H:%M:%S %p')) # 日期显示按AM,PM显示,输出:13:35:36 PM
print(format(now, '%a')) # 英文星期简写,输出:Sun
print(format(now, '%A')) # 英文星期完整显示,输出:Sunday
week = ['星期日', '星期一', '星期二', '星期三', '星期四', '星期五', '星期六']
print(week[int(format(now, '%w'))]) # 中文星期,输出:星期日

dt = datetime.datetime(2020, 5, 9)
dm = datetime.datetime(2020, 5, 9, 12, 50, 20)
# 将输入的日期按年-月-日和时间格式化,因时间没有输入,按0时处理
print(format(dt, '%Y-%m-%d %H:%M:%S'))
print(format(dt, '%Y-%m-%d')) # 将输入的日期按年-月-日格式化
print(format(dm, '%Y-%m-%d %H:%M:%S')) # 将输入的日期按年-月-日和时间格式化
print(format(dm, '%Y-%m-%d')) # 将输入的日期按年-月-日格式化

wx = datetime.datetime.now()
print(str(wx), format(1, '0>3')) # 年-月-日 +3位编号
print(format(now, '%Y-%m-%d'), format(1, '0>3')) # 年-月-日 +3位编号
print(format(now, '%Y%m%d'), 'NO' + format(1, '0>3')) # 年-月-日 +NO+3位编号
print(format(now, '%d'), 'NO' + format(1, '0>3')) # 日期 +NO+3位编号
print(format(now, '%H%M'), 'NO' + format(1, '0>3')) # 时钟+分 +NO+3位编号

四、使用 f-string 方法

f-string 是 Python3.6 新增的一种字符串格式方法,由于前面已经介绍了多种格式化方式,大同小异,此处用简单的案例对其用法进行演示。

【示例1】使用 f-string 方法在字符串中嵌入变量和表达式

name = "Python" # 字符串
ver = 3.6 # 浮点数
# 输出:Python-3.6、Python-3.7、Python-3.8000000000000003
print(f"{name}-{ver}、{name}-{ver + 0.1}、{name}-{ver + 0.2}")

【示例2】在示例 1 中,表达式计算浮点数时发生溢出,可以使用特殊格式化修饰符限定只显示 1 位小数。

name = "Python" # 字符串
ver = 3.6 # 浮点数
# 输出:Python-3.6、Python-3.7、Python-3.8
print(f"{name}-{ver}、{name}-{ver + 0.1}、{name}-{ver + 0.2:.1f}")

【示例3】把十六进制数字 10 分别转换为用十进制、十六进制、八进制和二进制表示。

n = 0x10 # 十六进制数字10
# 输出:dec:16, hex:10, oct:16, bin:10000
print(f"dec:{n:d}, hex:{n:x}, oct:{n:0}, bin:{n:b}")

【示例4】如果要在多行中表示字符串,可以使用下面示例方式,在每一行子串前面都加上 f 修饰符。

name = "Python" # 字符串
ver = 3.6 # 浮点数
s = f"{name}-" \
 f"{ver}"
print(s) # 输出:Python-3.6

到此这篇关于全网最细 Python 格式化输出用法讲解的文章就介绍到这了,更多相关 Python 格式化输出用法内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Python格式化输出%s和%d

    本文介绍了Python格式化输出%s和%d的实例案例.分享给大家供大家参考,具体如下: python print格式化输出 1. 打印字符串 print ("His name is %s"%("Aviad")) 效果: 2.打印整数 print ("He is %d years old"%(25)) 效果: 3.打印浮点数 print ("His height is %f m"%(1.83)) 效果: 4.打印浮点数(指定保留

  • 浅谈Python 字符串格式化输出(format/printf)

    Python 字符串格式化使用 "字符 %格式1 %格式2 字符"%(变量1,变量2),%格式表示接受变量的类型.简单的使用例子如下: # 例:字符串格式化 Name = '17jo'   print 'www.%s.com'%Name   >> www.17jo.com Name = '17jo' Zone = 'com' print 'www.%s.%s'%(Name,Zone) >> www.17jo.com 字符串格式化时百分号后面有不同的格式符号,代表

  • python中的格式化输出用法总结

    本文实例总结了python中的格式化输出用法.分享给大家供大家参考,具体如下: Python一共有两种格式化输出语法. 一种是类似于C语言printf的方式,称为 Formatting Expression >>> '%s %d-%d' % ('hello', 7, 1) 'hello 7-1' 另一种是类似于C#的方式,称为String Formatting Method Calls >>> '{0} {1}:{2}'.format('hello', '1', '7'

  • python常见的格式化输出小结

    本文总结了一些简单基本的输出格式化形式,下面话不多说了,来看看详细的介绍吧. 一.打印字符串 >>> print "I'm %s" % ("jihite") I'm jihite 二.打印整数 >>> print "I'm %d years old" % (17) I'm 17 years old 三.打印浮点数 >>> print "π=%f" % (3.1415926)

  • Python中使用pprint函数进行格式化输出的教程

    pprint – 美观打印 作用:美观打印数据结构 pprint 包含一个"美观打印机",用于生成数据结构的一个美观视图.格式化工具会生成数据结构的一些表示,不仅可以由解释器正确地解析,而且便于人类阅读.输出尽可能放在一行上,分解为多行时则需要缩进. 以下实例用用到的data包含一下数据 data = [(1,{'a':'A','b':'B','c':'C','d':'D'}), (2,{'e':'E','f':'F','g':'G','h':'H', 'i':'I','j':'J',

  • python中日期和时间格式化输出的方法小结

    本文实例总结了python中日期和时间格式化输出的方法.分享给大家供大家参考.具体分析如下: python格式化日期时间的函数为datetime.datetime.strftime():由字符串转为日期型的函数为:datetime.datetime.strptime(),两个函数都涉及日期时间的格式化字符串,这里提供详细的代码详细演示了每一个参数的使用方法及范例. 下面是格式化日期和时间时可用的替换符号 %a 输出当前是星期几的英文简写 >>> import datetime >&

  • Python格式化输出字符串方法小结【%与format】

    python格式化字符串有%和{}两种 字符串格式控制符. 字符串输入数据格式类型(%格式操作符号) %% 百分号标记#就是输出一个% %c 字符及其ASCII码 %s 字符串 %d 有符号整数(十进制) %u 无符号整数(十进制) %o 无符号整数(八进制) %x 无符号整数(十六进制) %X 无符号整数(十六进制大写字符) %e 浮点数字(科学计数法) %E 浮点数字(科学计数法,用E代替e) %f 浮点数字(用小数点符号) %g 浮点数字(根据值的大小采用%e或%f) %G 浮点数字(类似

  • 全网最细 Python 格式化输出用法讲解(推荐)

    一.使用 print() 函数 在 Python 中,print() 函数支持格式化输出,与 C 语言的 printf 类似. 1. 格式化输出字符串和整数 [示例1]输出字符串 AmoXiang,并计算.输出它的字符长度 str1 = "%s.length = %d" % ("AmoXiang", len("AmoXiang")) print(str1) # 输出AmoXiang.length = 8 % 在字符串中表示格式化操作符,它后面必须

  • python格式化输出%s与format()的用法对比

    目录 1.python格式化输出历史起源 2.为什么要学习python3支持的新式格式化输出呢? 3.基本用法 format()支持位置格式化填充,%s不支持: 4.填充和对齐 1)填充(只能用一个字符进行填充) 2)对齐 5.截断 6.格式化输出中,与数字相关的语法 1)引入案例 2)填充整数,使用d 3)填充浮点数,使用f(这个才是最常用的,用于保留小数点的位数): 1.python格式化输出历史起源 python2.5之前,我们使用的是老式格式化输出:%s.从python3.0开始起(py

  • Python格式化输出之format用法详解

    目录 format用法 一.填充 1.无参(1) 2.无参(2) 3.无参(3) 4.key value 5.列表 6.字典 7.类 8.魔法参数 二.数字格式化 三.叹号用法 总结 format用法 相对基本格式化输出采用‘%’的方法,format()功能更强大,该函数把字符串当成一个模板,通过传入的参数进行格式化,并且使用大括号‘{}’作为特殊字符代替‘%’ 使用方法由两种:b.format(a)和format(a,b). 一.填充 1.无参(1) print('{} {}'.format(

  • python中entry用法讲解

    小编之前向大家讲解了很多关于字符串的知识,大家也都知道字符串在python中的作用很大,那你知道在python中用于接收字符串等输入,让用户可与之交互以输入或操作字符串数据的对象是什么吗?是 python tkinter中的Entry 控件,下面我们来一看看吧. 1.Entry:用于接受用户Entry小窗口部件单行文本字符串 2.使用 Entry 控件的语法 w = Entry(master, option, ...) 注意:master 参数为其父控件, 就是用来放置这个 Entry 的控件.

  • Python格式化输出详情

    目录 1.%格式化 1.1简单格式化,不使用可选参数 1.2 复杂格式化,使用可选参数 1.2.1参数 (name),用于选择指定的key 1.2.2参数flags和width,对齐方式和宽度 1.2.3参数.precision 控制小数点后位数 2.format格式化 2.1自定义占位符 2.2自定义关键字 2.3填充与对齐(同时使用) 2.4数字格式化 3.f-String格式化 3.1简单使用 3.2复杂控制 1.%格式化 语法: %[(name)][flags][width].[prec

  • python格式化输出实例(居中、靠右及靠左对齐)

    目录 format 方式 其他扩展写法 '%' 方式 总结 format 方式 {: >} 靠右对齐 print('{0:>5}'.format('aa')) # 占5个字符空间,0是format参数中的变量索引 >> ' aa' {: <} 靠左对齐 print('{0:<5}'.format('aa')) # 占5个字符空间,0是format参数中的变量索引 >> 'aa ' {:^} 居中对齐 print('{0:^5}'.format('aa'))

  • Python格式化输出的具体实现

    目录 “%”的使用 字符串输出(%s) 浮点数输出(%f) format的使用 位置匹配 格式转换 高阶用法 format变形用法 “%”的使用 格式符 描述 %s 字符串 (采用str()的显示) %r 字符串 (采用repr()的显示) %c 单个字符及其ASCII码 %u 整数(无符号) %b 二进制整数 %o 八进制数(无符号) %d 十进制整数 %i 十进制整数 %x 十六进制数(无符号) %X 十六进制数大写(无符号) %e 指数 (基底写为e),用科学计数法格式化浮点数 %E 指数

  • python 格式化输出百分号的方法

    python的百分号输出比较奇怪,代码如下 print('%s%%'%(5))#这样就能输出'5%' 以上这篇python 格式化输出百分号的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们.

  • python格式化输出保留2位小数的实现方法

    我是小白就不用多说了,学习python做了个练习题,结果运行了一遍,发现输入金额后得到的有很多位小数, 虽然不知道为什么,但是看得很不舒服, 就想到应该把让小数点后只保留2位数 找到了方法:将{0}改为{:.2f} # 一家商场在降价促销.如果购买金额50-100元(包含50元和100元)之间, # 会给10%的折扣,如果购买金额大于100元会给20%折扣.编写一程序, # 询问购买价格,再显示出折扣(%10或20%)和最终价格 sum_money = float(input('请输入购买总金额

随机推荐