技巧 | 5000字超全解析Python三种格式化输出方式【% / format / f-string】

本文涉及的产品
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
全局流量管理 GTM,标准版 1个月
简介: 技巧 | 5000字超全解析Python三种格式化输出方式【% / format / f-string】


本期导读

大家好,我是欧K。

在编程学习中,我们经常会遇到各式各样的格式化输出要求,比如保留多少位小数,设置输出宽度,字符串补齐等等,本期就为大家详细解析python中经常用到的三种格式化方式:%(占位符)/format/f-string,希望对你有所帮助。


准备工作:

  • %c: 格式化字符及其ASCII码
  • %s: 格式化字符串(常用)
  • %d: 格式化整数(常用)
  • %u: 格式化无符号整型(常用)
  • %o: 格式化无符号八进制数
  • %x: 格式化无符号十六进制数(常用)
  • %X: 格式化无符号十六进制数(大写)
  • %f: 格式化浮点数字,可指定小数点后的精度(常用)
  • %e: 用科学计数法格式化浮点数(常用)
  • %E: 作用同%e,用科学计数法格式化浮点数
  • %g: %f和%e的简写
  • %G: %F 和 %E 的简写
  • %p: 用十六进制数格式化变量的地址
  • %%:格式化百分号标记
  • ^:格式化居中对齐(常用)
  • >式化右对齐(常用)
  • <式化左对齐(常用)
  • +:式化显示正负号(常用)



1. %(占位符)

声明三个变量:姓名(string)、年龄(int)、身高(float)

name = 'Python 当打之年'
age = 99
height = 1.85

1.1 混合整数(%d)、浮点数(%f)、字符串(%s)

print('我是:%s, 年龄:%d, 身高:%fm' % (name,age,height))
# 我是:Python 当打之年, 年龄:99, 身高:1.850000m
print('我是:%s, 年龄:%d, 身高:%.2fm' % (name,age,height))
# 我是:Python 当打之年, 年龄:99, 身高:1.85m

注意:浮点数默认精度为6,即小数点后6位。


1.2 进制数

输出十六进制、十进制、八进制数(比较常用):

%x --- hex 十六进制

%d --- dec 十进制

%o --- oct 八进制

print("age_hex = %x, age_dec = %d, age_oct = %o" %(age,age,age))
# age_hex = 63, age_dec = 99, age_oct = 143

如果需要输出二进制的话,可以使用python函数 bin()

print(bin(age)) # 0b1100011


1.3 宽度对齐精度填充1.3.1 数值型(默认右对齐)格式化输出圆周率(pi = 3.1415926):

pi = 3.1415926
print('%10.3f' % pi) #       3.142
# 宽度为10,右对齐,保留3位小数点
print('%-10.10f' % pi) # 3.1415926000
# 宽度为10,左对齐,保留小数点后10位(不足10位补0)


1.3.2 字符串

print( "%.10s " % name) # Python 当打之
# 输出10个字符,如果不足,输出全部
print ("%.*s" % (6,name)) # Python
# 左对齐,取6个字符
print ("%10.6s" % name) #       Python
# 右对齐,宽度为10,取6个字符

1.4 正负号

带符号输出,即正数(+),负数(-):

print('%+10.3f' % pi) # 3.142
# 宽度为10,右对齐,保留3位小数点
a = -pi
print('%+-10.3f' % a) # -3.142
# 宽度为10,左对齐,保留3位小数点

2. format格式化

Python2.6 开始,新增了一种格式化字符串的函数 str.format(),它增强了字符串格式化的功能。


2.1 混合


2.1.1 不设置位置


不设置位置参数时,参数默认从0 开始编号,依次为0,1,2,3......:

print('我是:{}, 年龄:{}, 身高:{}m'.format (name,age,height))
# 我是:Python 当打之年, 年龄:99, 身高:1.85m


2.1.2 设置位置


设置位置参数时,参数根据实际编号对应变量索引,注意{}中编号:

print('我是:{0}, 年龄:{1}, 身高:{2}m'.format (name,age,height))
# 我是:Python 当打之年, 年龄:99, 身高:1.85m
print('我是:{0}, 年龄:{1}, 身高:{1}m'.format (name,age,height))
# 我是:Python 当打之年, 年龄:99, 身高:99m
print('我是:{0}, 年龄:{2}, 身高:{1}m'.format (name,age,height))
# 我是:Python 当打之年, 年龄:1.85, 身高:99m


2.1.3 单变量参数


可以将索引编号设置为关键字,关键字需要有相应赋值:

print('我是:{name}, 年龄:{age}, 身高:{height}m'.format(name='Python 当打之年', age=99, height=1.85))
# 我是:Python 当打之年, 年龄:99, 身高:1.85m


2.1.4 列表参数

参数也可以是列表,注意多维列表需要指定为一维列表,'{0[0]}', '{0[1]}', '{0[2]}' 中'0'是必须的:

lst = [['Python 当打之年', 99, 1.85],['Python 当打之年', 18, 1.85]]
print('我是:{0[0]}, 年龄:{0[1]}, 身高:{0[2]}m'.format(lst[0]))
# 我是:Python 当打之年, 年龄:99, 身高:1.85m
print('我是:{0[0]}, 年龄:{0[1]}, 身高:{0[2]}m'.format(lst[1]))
# 我是:Python 当打之年, 年龄:18, 身高:1.85m

2.1.5 字典参数


当参数为字典时,可以使用关键字:

dic = {'name':'Python 当打之年','age':99,'height':1.85}
print('我是:{name}, 年龄:{age}, 身高:{height}m'.format(**dic))
# 我是:Python 当打之年, 年龄:99, 身高:1.85m

2.2 宽度对齐精度填充

宽度为10,居中、居右、居左对齐:

a = 66
print('{:^10d}'.format(a)) # 宽度10,居中
print('{:>10d}'.format(a)) # 宽度10,居右
print('{:<10d}'.format(a)) # 宽度10,居左
#     66
#         66
# 66


保留2、3位有效数字,百分比以及指数计数法:

pi = 3.1415926
print("{:.2f}".format(pi)) # 不带符号
print("{:+.3f}".format(pi)) # 带符号
print("{:.4%}".format(pi)) # 百分比
print("{:.2e}".format(pi)) # 指数计数法
# 3.14
# +3.142
# 314.1593%
# 3.14e+00


可以使用不同字符进行填充(补齐):

print('{:0^10d}'.format(a)) # 宽度10,居中
print('{:a>10d}'.format(a)) # 宽度10,居右
print('{:0<10d}'.format(a)) # 宽度10,居左
# 0000660000
# aaaaaaaa66
# 6600000000
print('{:0^30}'.format(name)) # 宽度30,居中
print('{:0>30}'.format(name)) # 宽度30,居右
print('{:0<30}'.format(name)) # 宽度30,居左
# 000000000Python 当打之年0000000000
# 0000000000000000000Python 当打之年
# Python 当打之年0000000000000000000
print('Hello {0:>{1}} '.format(name,20))
# Hello                    Python 当打之年


2.3 千位分隔符

主要用于货币数据格式化输出,用逗号表示,当然也可以用其他字符替代:


print('{:,}'.format(100000000))
print('{:,}'.format(1234567.1234567))
# 100,000,000
# 1,234,567.1234567
print('{0:-^20,}'.format(1234567.1234567))
print('{0:->20,}'.format(1234567.1234567))
print('{0:-<20,}'.format(1234567.1234567))
# -1,234,567.1234567--
# ---1,234,567.1234567
# 1,234,567.1234567---


3. f-string格式化

f-string格式化是python3.6引入了一种新的字符串格式化方式。


3.1 单变量参数


变量名直接做参数,比如name, age, height,注意不需要单引号或双引号:

print(f'我是:{name}, 年龄:{age}, 身高:{height}m')
# 我是:Python 当打之年, 年龄:99, 身高:1.85m


3.2 表达式参数

可以是直接的数值运算,也可以是变量赋值后运算:

print(f'计算结果是:{2*5 + 3*4}')
# 计算结果是:22
a = 90
b = 9
print(f'计算结果是:{a*b + a + b}')
# 计算结果是:909


3.3 函数参数

普通函数作为参数、lambda函数作为参数:

name = 'PYTHON当打之年'
print(f'我是:{name}')
print(f'我是:{name.lower()}')
# 我是:PYTHON当打之年
# 我是:python当打之年
a = 90
b = 9
print(f'计算结果是:{(lambda x,y:x+y)(a,b)}')
# 计算结果是:99

3.4 宽度对齐精度填充


宽度为10,精度为小数点后2、3、4位,居中、居右、居左对齐,填充方式和format一样可以选择不同的字符:

pi = 3.1415926
print(f'{pi:^10.2f}')
print(f'{pi:>10.3f}')
print(f'{pi:<10.4f}')
#      3.14
#        3.142
# 3.1416
print(f'{pi:a^10.2f}')
print(f'{pi:a>10.3f}')
print(f'{pi:a<10.4f}')
# aaa3.14aaa
# aaaaa3.142
# 3.1416aaaa


3.5 千位分隔符主要用于货币数据格式化输出,用逗号表示,同样也可以用其他字符替代:

a = 1234567.1234567
print(f'{a:,f}')
print(f'{a:_f}')
# 1,234,567.123457
# 1_234_567.123457

总结:

%(占位符):优点:在简单练习中,表达比较直观,易于掌握。缺点:随着参数数量的增加,格式输入会逐渐变得繁琐。format:优点:可以根据编号设置单个参数多次输出,填充方式比较灵活。缺点:随着参数数量的增加,输入长度会逐渐增加,当有大量参数时,同样比较繁琐。f-string:优点:格式化的方式较前两种更加直观,效率也较前两个高一些。

缺点:新的格式化方式,有些语句格式较前两中复杂一些。

上面三种格式化方式我们都可以使用,大家在学习过程中,可以根据自己的实际情况选择格式化方式,比较推荐f-string方式


END


以上就是本期为大家整理的全部内容了,赶快练习起来吧,喜欢的朋友可点赞、点在看也可以分享到朋友圈让更多人知道哦

相关文章
|
1天前
|
存储 索引 Python
Python入门:6.深入解析Python中的序列
在 Python 中,**序列**是一种有序的数据结构,广泛应用于数据存储、操作和处理。序列的一个显著特点是支持通过**索引**访问数据。常见的序列类型包括字符串(`str`)、列表(`list`)和元组(`tuple`)。这些序列各有特点,既可以存储简单的字符,也可以存储复杂的对象。 为了帮助初学者掌握 Python 中的序列操作,本文将围绕**字符串**、**列表**和**元组**这三种序列类型,详细介绍其定义、常用方法和具体示例。
Python入门:6.深入解析Python中的序列
|
1天前
|
存储 Linux iOS开发
Python入门:2.注释与变量的全面解析
在学习Python编程的过程中,注释和变量是必须掌握的两个基础概念。注释帮助我们理解代码的意图,而变量则是用于存储和操作数据的核心工具。熟练掌握这两者,不仅能提高代码的可读性和维护性,还能为后续学习复杂编程概念打下坚实的基础。
Python入门:2.注释与变量的全面解析
|
7天前
|
监控 算法 安全
内网桌面监控软件深度解析:基于 Python 实现的 K-Means 算法研究
内网桌面监控软件通过实时监测员工操作,保障企业信息安全并提升效率。本文深入探讨K-Means聚类算法在该软件中的应用,解析其原理与实现。K-Means通过迭代更新簇中心,将数据划分为K个簇类,适用于行为分析、异常检测、资源优化及安全威胁识别等场景。文中提供了Python代码示例,展示如何实现K-Means算法,并模拟内网监控数据进行聚类分析。
28 10
|
25天前
|
存储 算法 安全
控制局域网上网软件之 Python 字典树算法解析
控制局域网上网软件在现代网络管理中至关重要,用于控制设备的上网行为和访问权限。本文聚焦于字典树(Trie Tree)算法的应用,详细阐述其原理、优势及实现。通过字典树,软件能高效进行关键词匹配和过滤,提升系统性能。文中还提供了Python代码示例,展示了字典树在网址过滤和关键词屏蔽中的具体应用,为局域网的安全和管理提供有力支持。
50 17
|
28天前
|
运维 Shell 数据库
Python执行Shell命令并获取结果:深入解析与实战
通过以上内容,开发者可以在实际项目中灵活应用Python执行Shell命令,实现各种自动化任务,提高开发和运维效率。
56 20
|
1月前
|
数据采集 供应链 API
Python爬虫与1688图片搜索API接口:深度解析与显著收益
在电子商务领域,数据是驱动业务决策的核心。阿里巴巴旗下的1688平台作为全球领先的B2B市场,提供了丰富的API接口,特别是图片搜索API(`item_search_img`),允许开发者通过上传图片搜索相似商品。本文介绍如何结合Python爬虫技术高效利用该接口,提升搜索效率和用户体验,助力企业实现自动化商品搜索、库存管理优化、竞品监控与定价策略调整等,显著提高运营效率和市场竞争力。
89 3
|
2月前
|
数据采集 JSON API
如何利用Python爬虫淘宝商品详情高级版(item_get_pro)API接口及返回值解析说明
本文介绍了如何利用Python爬虫技术调用淘宝商品详情高级版API接口(item_get_pro),获取商品的详细信息,包括标题、价格、销量等。文章涵盖了环境准备、API权限申请、请求构建和返回值解析等内容,强调了数据获取的合规性和安全性。
|
2月前
|
数据挖掘 vr&ar C++
让UE自动运行Python脚本:实现与实例解析
本文介绍如何配置Unreal Engine(UE)以自动运行Python脚本,提高开发效率。通过安装Python、配置UE环境及使用第三方插件,实现Python与UE的集成。结合蓝图和C++示例,展示自动化任务处理、关卡生成及数据分析等应用场景。
178 5
|
2月前
|
存储 缓存 Python
Python中的装饰器深度解析与实践
在Python的世界里,装饰器如同一位神秘的魔法师,它拥有改变函数行为的能力。本文将揭开装饰器的神秘面纱,通过直观的代码示例,引导你理解其工作原理,并掌握如何在实际项目中灵活运用这一强大的工具。从基础到进阶,我们将一起探索装饰器的魅力所在。
|
2月前
|
Android开发 开发者 Python
通过标签清理微信好友:Python自动化脚本解析
微信已成为日常生活中的重要社交工具,但随着使用时间增长,好友列表可能变得臃肿。本文介绍了一个基于 Python 的自动化脚本,利用 `uiautomator2` 库,通过模拟用户操作实现根据标签批量清理微信好友的功能。脚本包括环境准备、类定义、方法实现等部分,详细解析了如何通过标签筛选并删除好友,适合需要批量管理微信好友的用户。
108 7

推荐镜像

更多