详解Python中的str.format方法

字符串的内置方法大致有40来个,但是一些常用的其实就那么20几个,而且里面还有类似的用法,区分度高比如:isalpha,isalnum,isdigit,还有一些无时不刻都会用到的split切分,join拼接,strip首尾去指定字符,作用无非就是围绕字符串的增删改查来进行,本人认为要弄清楚和熟练使用这些常用的方法,一方面需要在理解的基础上多多练习多多回顾,同时在工作使用中去巩固,加深记忆。忘记没关系,善于总结归纳,善于对自己大脑记忆的‘增删改查’才是重点。

str.format的意义:

作为一个初学者,最近发现字符串中最繁杂的一个方法莫过于:str.format()了,format见名思义,格式化,格式化完为了干嘛,其实就是为了得到我们需要格式的数据,也就是格式化输出,格式化输出我们一开始学习的是用%s、%d来实现,但是这种方法有很多局限性,比如%s是按照位置格式化输出,局限性显而易见,如果一次性格式化输出太多,还是根据位置来输出的话就太容易出错了。所以更精确的一种格式化输出方法就是str.format()

str.format方法介绍:

1、通过字符串中的花括号{}来识别替换字段,从而完成字符串的格式化。

2、替换的内容包括:字段名、格式说明符三部分,形式一般为:{字段名:格式说明符}

以上是简介,下面是干货:

具体实现:

1、简单实现方法:

(1)省略不写{} ____写法类似%s按位置格式化输出

(2)数字{十进制非负整数} ____写法类似依据位置索引传参

(3)变量名{关键字} ____写法类似关键字参数传参

(4)可以混合使用

1.1 省略不写:花括号内省略不写,代表传递位置参数

替换字段形式{}

注意事项:花括号个数少于等于后面的位置参数的个数,多了肯定报错。

# 用{}代表占位符,直接位置传参
print('我是{},喜欢{}!'.format('灭霸','打响指'))
# 我是灭霸,喜欢打响指!
# {}数量必须少于后面位置参数数量,不然报错
print('我是{},喜欢{},不喜欢{}。'.format('宙斯','放大抢人头','放空大','小短腿'))
print('我是{},喜欢{},不喜欢{}。'.format('宙斯','放大抢人头'))
# 报错误:IndexError: tuple index out of range

1.2 数字形式传参:通过位置索引值传递位置参数

索引从整数0开始

索引可以重复引用,输出

索引数值就是后面位置参数放入一个元组来取值的过程,所以索引数值不能大于元组里面位置参数的索引值,否则报错

print('我身高{0},年龄正好{1},{2}长。'.format('180cm',18,'15cm'))
# 我身高180cm,年龄正好18,15cm长。
print('我身高{0},{0}不多不少,年龄正好{1}。'.format('180cm',18))
# 我身高180cm,180cm不多不少,年龄正好18。
print('我身高{0},年龄正好{1},{2}长。'.format('180cm',18))
# IndexError: tuple index out of range

1.3 变量名{关键字} 传递输出参数

想想关键字参数怎么传参,类比一下,bingo!

特别注意,关键字的变量名在参数那里无需加引号,同时{}里面引用直接填变量名。

print('我的名字叫{name},我其实是一名{career}!'.format(name='尹天仇',career='演员'))
# 我的名字叫尹天仇,我其实是一名演员!
print('我叫{name2},又名{name1},我弟弟叫{name3}!'.format(name1='至尊宝',name2='秦汉',name3='秦祥林'))
# 我叫秦汉,又名至尊宝,我弟弟叫秦祥林!

1.4 {}、{0}、{name}混合使用

位置参数在前,关键字参数在后

{}不能与数字形式{0}同时使用。

print('吹个{0},吹个{2},吹大了{1},玩{ball}!'.format('球','气球','大气球',ball='球球'))
# 吹个球,吹个大气球,吹大了气球,玩球球!
print('吹个{},吹大了{},玩{ball}!'.format('球','气球','大气球',ball='球球'))
# 吹个球,吹大了气球,玩球球!
print('吹个{0},吹大了{1},玩{ball}!'.format('球','气球','大气球',ball='球球'))
# 吹个球,吹大了气球,玩球球!
print('吹个{0},吹大了{},玩{ball}!'.format('球','气球','大气球',ball='球球'))
#报错 ValueError: cannot switch from manual field specification to automatic field numbering

2、使用元组和字典传参:

str.format()方法可以使用*元组和**字典的形式传参,可以混用。

方法相当于*args和**kwargs打散传参,元组按位置或索引传参,字典按关键字传参。

位置参数、关键字参数、*元组、**字典也可以同时使用,但要注意位置参数在关键字参数前,*元组要在**字典前。

# 元组
print('我喜欢{},喜欢{},同时也喜欢{}!'.format(*('篮球','足球','观球')))
# 我喜欢篮球,喜欢足球,同时也喜欢观球!
print('我喜欢{0},喜欢{1},同时也喜欢{2}!'.format(*('篮球','足球','观球')))
# 我喜欢篮球,喜欢足球,同时也喜欢观球!
# 字典
print('{name}的女朋友是{gf},我也喜欢{gf}!'.format(**{'name':'钢铁侠','gf':'小辣椒'}))
# 钢铁侠的女朋友是小辣椒,我也喜欢小辣椒!
# 元组+字典
print('我是{beauty}的{1},我们都喜欢{0},请大家{2}!'\.format(*('球类','球迷','文明观球'),**{'beauty':'斯嘉丽约翰逊',}))
# 我是斯嘉丽约翰逊的球迷,我们都喜欢球类,请大家文明观球!
# 位置参数、关键字参数、元组、字典混合使用:
print('我是{name},好像{age}了 ^_^,在{0},等你哦!\n喜欢{1}、{2}和{3}。\n我的唯一 >>>:{only_one}\n我的小可爱 >>>: {love}!'\.format('武汉',name='苏光体',age=18,*('读书','健身','折腾数码'),**{'only_one':'杨林','love':'苏弘睿'}))
# 我是苏光体,好像18了 ^_^,在武汉,等你哦!
# 喜欢读书、健身和折腾数码。
# 我的唯一 >>>:杨林
# 我的小可爱 >>>: 苏弘睿!

使用元组或者字典格式化输出的形式就是相当于将元组和字典打散,变成位置参数们和关键字参数们然后按照前面的方法传参就行。

3、对象参数格式化输出传值:

formate还可以使用对象属性传参,这个对象可以是实例化的对象,也可以是列表、字典。

# 对象属性传参
# 实例化对象:
class Dog:def __init__(self,name,speak):self.name=nameself.speak=speak
dog1=Dog('小黄','汪汪汪')
print('我的{0.name}会{0.speak}。'.format(dog1))
# 我的小黄会汪汪汪。
# 文件对象
with open('text.txt','wb') as f:print('打开的文件名为:{0.name}'.format(f))
# 打开的文件名为:text.txt
# 列表、字典对象
print('I have a {0[0]} , I have a {0[1]} .'.format(['Apple','Pen']))
print('我叫{0[name]},{0[id]}就是我!'.format({'name':'阿星','id':'9527'}))
print('{1[name]}变成了{0[0]},藏进了{1[role]}的裤裆里,为什么不变{0[1]}而是{0[0]}呢?'.format(['葡萄','苹果'],{'name':'菩提老祖','role':'至尊宝'}))
# I have a Apple , I have a Pen .
# 我叫阿星,9527就是我!
# 菩提老祖变成了葡萄,藏进了至尊宝的裤裆里,为什么不变苹果而是葡萄呢?

4、格式说明符:规定传入参数字符的格式

比如:

print('{0:.4f}'.format(3.1415926))
#在传入参数后面用冒号:写入规定的格式:.4f(取4位小数) 结果为:3.1416

说明符格式标准:[填充]对齐方式][正负号][#][0][宽度][分组选项][.精度][类型码]   同时存在是有顺序之分的,具体使用下面有具体示例:

填充:

(1)填充字符只能有一个

(2)不指定默认用空格填充

(3)如果指定填充字符,则必须要同时指定对齐方式

对齐方式:

(1)<    左对齐

(2)>    右对齐

(3)^    居中对齐

(4)=    在正负号和数字之间填充(仅对数字类型有效)可以输出类似:+00000012的字符串。

正负号:

(1)仅对数字类型生效

(2)+ - 正负号

(3)空格:正数前面需要添加一个空格,以便与负数对齐

宽度width

(1)不指定宽度,宽度由内容决定

(2)宽度前有0,意味着用0填充,等价于 0=的填充和对齐方式

精度

(1)指小数点后面展示的小数位数。

(2)对于非数字类型,指字段宽度。

(3)整数类型不能指定精度,会报错的。

下面看示例吧:

#在传入参数后面用冒号:写入规定的格式:.4f(取4位小数) 结果为:3.1416
# 填充、对齐、宽度
print('{0:人>2}'.format('<我是谁>'))   # 宽度不够,按实际字符显示
print('{0:人<11}'.format('<我>'))
print('{0:人^11}'.format('<我>'))
# <我是谁>
# <我>人人人人人人人人
# 人人人人<我>人人人人
# 正负号、精度
print('{0:*=+10.4f}'.format(3.1415926))  # '*'>填充符,'='>指定在正负号和数字之间填充,'10'>宽度,'.4f'>精度
print('{0:*>+10.4f}'.format(3.1415926))  # 同上,'>'>右对齐
# +***3.1416
# ***+3.1416
print('{0:&>10.4f}'.format(3.1415926))
print('{0:&<10.4f}'.format(3.1415926))
print('{0:&>10.4}'.format('我是中国人'))  # 精度为4,去字符串中的前4个字符
# &&&&3.1416
# 3.1416&&&&
# &&&&&&我是中国

类型码(规定输出的数据类型)

(1)字符串类型

(2)整数类型

(3)浮点数类型

# 字符串类型(默认类型,忽视)
print('{0:s}'.format('abc'))    # abc
print('{0:}'.format('abc'))     # abc
# 整数类型
# b 二进制|c Unicode字符|d 十进制整数|还有很多比如o八进制|x十六进制...等等
print('{0:b}'.format(101))     # 1100101
print('{0:c}'.format(101))     # e
print('{0:d}'.format(666))     # 666
# 浮点数字类型
# e 科学计数(默认精度6位)
print('{0:e}'.format(31415926))   # 3.141593e+07
# f 定点记法(默认精度6位)
print('{0:f}'.format(3.1415926))   # 3.141593

以上例子可以说不太全面,只是大概举了几个常见的,除了e,f类型还有g通用类型,n number类型,对于日常使用的话并不常用。所以不一一列出。

5、其他补充:

花括号本事如需格式化输出,可以用外套2层花括号转义解决

print('{{0}}'.format('abc'))       # {0}
print('{{{0}}}'.format('abc'))     # {abc}

一些另类格式化输出:

from datetime import datetime
print('今天是:{0:%Y-%m %H:%M}'.format(datetime.now()))
# 结果:
今天是:2019-05 15:10

总结:

str.format()格式化输出方法可以说是%s的加强型,特别是在处理更复杂的格式化输出过程时候,可以更精确的进行达到输出目的,它集成的方法可以说比较繁杂,很多方法个人认为用处不大,仅仅是锦上添花的作用,个人认为只要掌握前面几个简单的位置参数、关键字参数、元组、字典的传参形式的格式化输出就可以了。后面的方法可以有,但是不建议进行强行记忆,因为精力有限,用时再打开翻翻也就明了。

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

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

相关文章

深度学习的新进展:探索人工智能的未来

文章目录 &#x1f4d1;引言深度学习技术概述计算机视觉领域的深度应用自然语言处理的深度革命跨领域应用的深度拓展深度学习的挑战与未来展望结语 &#x1f4d1;引言 在科技日新月异的今天&#xff0c;深度学习作为人工智能领域的一颗璀璨明珠&#xff0c;正在引领着技术创新…

Nvidia 推出了本地版聊天 Chat with RTX;OpenAI联创Karpathy宣布离职专注个人项目

&#x1f989; AI新闻 Nvidia 推出了本地版聊天 Chat with RTX 摘要&#xff1a;英伟达最近发布了名为“Chat with RTX”的Demo版个性化AI聊天机器人&#xff0c;适用于Windows平台&#xff0c;需要Nvidia的30系/40系显卡&#xff0c;显存至少为8GB&#xff0c;系统配置包括1…

极市平台 | 16个图像分类方向开源数据集资源汇总(附下载链接,建议收藏!)

本文来源公众号“极市平台”&#xff0c;仅用于学术分享&#xff0c;侵权删&#xff0c;干货满满。 原文链接&#xff1a;16个图像分类方向开源数据集资源汇总&#xff08;附下载链接&#xff09; 本文汇总了16个图像分类相关的开源数据集&#xff0c;均附有下载链接。要构建…

Shell 学习笔记(三)-shell变量

Shell 语言是一种动态类型和弱类型语言, 因此,在Shell中无需显示地声明变量, 且变量的类型会根据不同的操作符而发生变化. 静态类型语言: 在程序编译期间就确定变量类型的语言, 如java, C等 动态类型语言: 在程序运行期间才确定变量类型的语言, 如PHP, Python等. 一 shell变量…

姿态传感器MPU6050模块的基本使用总结

以下两篇文章可作为参考&#xff1a; 姿态传感器MPU6050原理及应用超详细讲解 - 采芯网 基于STM32的四旋翼无人机项目&#xff08;二&#xff09;&#xff1a;MPU6050姿态解算&#xff08;含上位机3D姿态显示教学&#xff09;-CSDN博客 基本介绍 随着科技的发展&#xff0c;我们…

保安员题不会怎么搜答案?推荐你使用这5个公众号和工具 #知识分享#微信#经验分享

大学生搜题软件是一种方便快捷的工具&#xff0c;可以帮助大学生们在解答问题和完成作业时节省时间和精力。 1.灵兔搜题 这是一个公众号 题库包括四六级答案、各学校往期课后答案、期末考试题等&#xff0c;使用比较简单。 下方附上一些测试的试题及答案 1、公民应当遵守下…

【MySQL】外键约束的删除和更新总结

&#x1f308;个人主页: Aileen_0v0 &#x1f525;热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法 ​&#x1f4ab;个人格言:“没有罗马,那就自己创造罗马~” #mermaid-svg-7niJLSFaPo0wso60 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-siz…

(二)【Jmeter】专栏实战项目靶场drupal部署

该专栏后续实战示例&#xff0c;都以该篇部署的项目展开操作。 前置条件 参考“&#xff08;一&#xff09;【Jmeter】JDK及Jmeter的安装部署及简单配置” 安装部署Jmeter&#xff0c;从文章最后下载“Postman、Rancher.ova、VirtualBox-7.0.12-159484-Win.exe、Xshell-7.0.01…

考研高数(导数的定义)

总结&#xff1a; 导数的本质就是极限。 函数在某点可导就必连续&#xff0c;连续就有极限且等于该点的函数值。 例题1&#xff1a;&#xff08;归结原则的条件是函数可导&#xff09; 例题2&#xff1a; 例题3&#xff1a;

python守护进程--supervisor 使用教程

supervisor 使用教程python守护进程1.安装 pip3 install supervisor -i https://pypi.tuna.tsinghua.edu.cn/simple 2.使用supervisor 启动 python main.py 文件 vim /etc/supervisor/conf.d/demo.conf添加以下内容&#xff1a;[program:demo] #项目名称为democommandp…

XML学习

XML学习 1 XML介绍2 XML语法3 XML特殊字符4 XML文档结构5 XML命名空间 1 XML介绍 XML是可扩展的标记性语言&#xff0c;常用来传输和存储数据。可见于Web中的web.xml和Maven中的pom.xml version是版本&#xff0c;encoding是编码 <?xml version"1.0" encodin…