全网最细 Python 格式化输出用法讲解
这篇文章主要介绍了全网最细 Python 格式化输出用法讲解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下一、使用 print() 函数在 Python 中,print() 函数支持格式化输出,与 C 语言的 printf 类似。1. 格式化输出字符串和整数【示例1】输出字符串 AmoXiang,并计算、输出它的字符长度12str1 = "%s.leng
这篇文章主要介绍了全网最细 Python 格式化输出用法讲解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
一、使用 print() 函数
在 Python 中,print() 函数支持格式化输出,与 C 语言的 printf 类似。
1. 格式化输出字符串和整数
【示例1】输出字符串 AmoXiang,并计算、输出它的字符长度
1 2 |
|
% 在字符串中表示格式化操作符,它后面必须附加一个格式化符号,具体说明如下表所示。
%()元组可以包含一个或多个值,如变量或表达式,用来向字符串中%操作符传递值,元组包含元素数量、顺序都必须与字符串中%操作符一一对应,否则将抛出异常。%()元组必须位于字符串的后面,否则无效。如果字符串中只包含一个%操作符,那么也可以直接传递值。例如:
1 2 |
|
2. 格式化输出不同进制数
【示例2】使用 print() 函数把数字输出为十六进制、十进制、八进制格式的字符串。
1 2 3 |
|
补充:整数类型包括十进制整数、八进制整数、十六进制整数和二进制整数。
十进制的整数不能以 0 开头。八进制整数由 0~7 组成,逢八进一,以 0o 或 0O 开头,例如:0o23十六进制整数由 0~9 以及 a~f 组成,逢十六进一,以 0x 或 0X 开头。例如:0x23二进制整数由 0 和 1组成,逢二进一,以 0b 或 0B 开头。例如:0b101关于进制这个知识点不懂的读者可以点击 进制转换 学习
十进制转成其他进制
# 10进制 -> 二进制
# 11 - > 1011
# 1011-> 8+2+1
# print(bin(11)) # 0b1011
# 10进制 -> 八进制
# print(oct(11)) # 0o13
# 10进制 -> 十六进制
# print(hex(11)) # 0xb
# print(hex(123)) # 0xb
# 2.2.2 其他制转成其十进制
# 二进制->10进制
# print(int('0b1011',2)) # 11
# 二进制->8进制
# print(int('0o13',8)) # 11
# 二进制->16进制
# print(int('0xb',16)) # 11
3. 格式化输出浮点数
【示例3】把数字输出为不同格式的浮点数字符串。
1 2 3 4 5 6 |
|
程序运行结果如下:
在格式化输出数字或字符串时,可以附加辅助指令来完善格式化操作。具体说明如下表所示:
二、使用 str.format() 方法
%
操作符是传统格式化输出的基本方法,从 Python 2.6 版本开始,为字符串数据新增了一种格式化方法 str.format()
,它通过 {}
操作符和 :
辅助指令来代替 %
操作符。
【示例1】通过位置索引值
1 2 3 |
|
在字符串中可以使用 {}
作为格式化操作符。与 %
操作符不同的是,{}
操作符可以通过包含的位置值自定义引用值的位置,也可以重复引用。
【示例2】通过关键字索引值
1 2 |
|
【示例3】通过下标进行索引
1 2 3 |
|
通过使用 format() 函数这种便捷的 映射
方式,列表和元组可以 打散
成普通参数传递给 format() 方法,字典可以打散成关键字参数给方法。format() 方法包含丰富的格式限定符,附带在 {}
操作符中 :
符号的后面。
1. 填充与对齐
:
符号后面可以附带填充的字符,默认为空格, ^、<、>
分别表示居中、左对齐、右对齐,后面附带宽度限定值。
【示例4】下面示例设计输出 8 位字符,并分别设置不同的填充字符和值对齐方式。
1 2 3 |
|
程序运行结果如下:
2. 精度与类型f
【示例5】f 与 float 类型数据配合使用
1 |
|
其中 .2f
表示小数点后面的精度为 2,f 表示浮点数输出。
3. 进制数字输出
【示例6】使用b、d、o、x 分别输出二进制、十进制、八进制、十六进制数字。
1 2 3 4 5 |
|
4. 千位分隔输出
【示例7】使用逗号(,)输出金额的千分位分隔符。
1 |
|
三、详解 format() 函数
format()函数可以对数据进行格式化处理操作。语法格式如下:
format_spec为格式化解释。当参数 format_spec 为空时,等同于函数 str(value) 的方式。value 为要转换的数据。format_ spec 可以设置非常复杂的格式转换参数,生成比较完备的数据格式处理模板。format_spec 的编写方式如下形式:
1 |
|
format_spec 格式控制符可以分为文字对齐、填充值、标志设置、格式化、类型转换、千位符(数字分组)等主要应用。细化分类说明如下图所示:
参数说明:
(1) fill(填充值):此处可以填写任何字符,通常与align、width一起使用,实现指定位数字符填充,通常格式如图1.2所示,填充效果及位置如图1.3所示。
通常用 0、*、#、@
等进行填充。如果不写填充值,则使用默认填充值,默认填充值为空格。代码如下:
1 2 3 4 |
|
(2) align(对齐方式):指在 width(数字宽度) 内输出时的对齐方式,分别使用 <、>、^、=
4个符号表示左对齐、右对齐、居中对齐和数字填充(只用于数字,在符号后进行补齐)。
(3) width(数字宽度):指设定输出字符宽度,如果数据的实际位数比 width 指定宽度值大,则使用数据实际的长度。如果该值的实际位数小于指定宽度,则位数将设定的 fill 值填充或设定的 0 值填充,如果没有设置填充值,则用空格填充。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
|
程序运行结果如下:
(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) 效果相同。如:
1 2 3 4 5 6 7 8 |
|
设置参数 format_spec 的值,可以进行相应数据类型的格式化,字符串可以提供的参数为 s。十进制整型提供的参数为 d 和 n,二进制的参数为 b,八进制的参数为 o,十六进制小写的参数为 x,十六进制大写的参数为 X,ASIIC 码的参数为 c,浮点数的参数为 f。以上格式化后的数据类型都为字符型,举例如下:
1 2 3 4 5 6 7 8 9 10 11 |
|
运用二:生成数据编号
利用 format() 函数实现数据编号。对数据进行编号,也是对字符串格式化操作的一种方式,使用 format() 函数可以对字符串进行格式化编号。只需设置填充字符(编号通常设置 0),设置对齐方式时可以使用 <、> 和 ^ 符号表示左对齐、右对齐和居中对齐,对齐填充的符号在 宽度
范围内输出时填充即可。对数字 1 进行 3 位编号,右对齐,需要设置 format() 函数的填充字符为 0,对齐方式为右对齐,宽度为 3。具体代码为:
1 2 3 |
|
要生成的编号通常比较复杂,如根据当天的日期建立编号,或者批量生成编号,或者将给定的批量数据中的数字转换成位数固定的编号,下面给出实现编号的代码:
1 2 3 4 5 6 7 8 9 10 |
|
批量生成编号:
1 2 3 |
|
程序运行结果如下:
1 2 3 4 5 |
|
程序运行结果如下:
要实现嵌套编号,如A001-A005、B001-B005、C001-005 的嵌套编号,代码如下:
1 2 3 4 5 |
|
程序运行结果如下:
运用三:格式化十进制整数
对于不同的类型数据,format() 函数的参数 format_spec 提供的值都不一样,对于十进制整数,整型数值可以提供的参数有d、n。具体如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 |
|
运用四:格式化浮点数
对于浮点数类型,可以提供的参数有e、E、f、F、g、G、n、%、None 等。
用 f 表示浮点类型,可以在其前边加上精度控制,用于控制输出宽度。如果输出位数大于宽度,就按实际位数输出。还可以为浮点数指定符号,+表示在正数前显示正号+。- 表示在负数前显示负号 - (- 与什么都不加({:f})时一致)。空格表示在正数前加空格,在负数前加 -,.3f 表示浮点数的精度为 3(小数位保留3位)。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 |
|
运用五:格式化百分数
在格式化解释中单独或者在精度之后添加 % 号,可以实现用百分数显示浮点数,如:
1 2 3 4 5 6 7 8 |
|
运用六:格式化科学记数法
如果要将浮点数采用科学记数法表示,可以在格式化模板中使用 e 和 E 或者 g 和 G。e 为通用的幂符号,用科学记数法打印数字,用 e 表示幂。使用 g 时,将数值以 fixed-point 格式输出。当数值特别大的时候,用幂形式输出。
1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
运用七:格式化金额
format() 函数还能用来作金额的千位分隔符。如果要实现金额前面带上相关货币的符号形式的功能,需要在该函数前面手动加上相应货币符号。如:
1 2 3 4 5 6 |
|
程序运行结果如下:
运用八:格式化字符
格式化字符主要包括截取字符串,字符串对齐方式显示,填充字符串等,代码如下:
1 2 3 4 5 6 7 8 9 10 11 |
|
程序运行结果如下:
运用九:进制转换
进制转换主要是进行十进制、十六进制、八进制、二进制的转换,如果是十六进制、八进制、二进制数,转换前最好保留进制前缀,如 Ox/0o/0b
,这样可以保证转换的准确性。主要进制转换符号说明如下:
b:二进制。将数字以 2 为基数进行输出。d:十进制整数。将数字以 10 为基数进行输出。o:八进制。将数字以 8 为基数进行输出。x:十六进制。将数字 以16 为基数进行输出,9 以上的数字用小写字母。
十进制、十六进制、八进制、二进制的转换代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
|
对于带有进制前缀的数,如 0x、0o、0b,可以直接在后面加上 x、o、b 进行删除。
1 2 3 |
|
运用十:格式化日期和时间
format() 函数也可以对日期和时间进行格式化,格式化时可以通过日期和时间格式符号进行设置,Python 中常用的时间日期格式化符号如表 1.1 所示。
常用操作代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 |
|
四、使用 f-string 方法
f-string 是 Python3.6 新增的一种字符串格式方法,由于前面已经介绍了多种格式化方式,大同小异,此处用简单的案例对其用法进行演示。
【示例1】使用 f-string 方法在字符串中嵌入变量和表达式
1 2 3 4 |
|
【示例2】在示例 1 中,表达式计算浮点数时发生溢出,可以使用特殊格式化修饰符限定只显示 1 位小数。
1 2 3 4 |
|
【示例3】把十六进制数字 10 分别转换为用十进制、十六进制、八进制和二进制表示。
1 2 3 |
|
【示例4】如果要在多行中表示字符串,可以使用下面示例方式,在每一行子串前面都加上 f 修饰符。
1 2 3 4 5 |
|
到此这篇关于Python 格式化输出用法讲解的文章就介绍到这了,
更多推荐
所有评论(0)