Python中str.format()详解


Posted in Python onMarch 12, 2017

1. str.format 的引入

在 Python 中,我们可以使用 + 来连接字符串,在简单情况下这种方式能够很好的工作。但是当我们需要进行复杂的字符串连接时,如果依然使用 + 来完成,不仅会使代码变得晦涩难懂,还会让代码变得难以维护,此时这种方式就显得力不从心了。

例如,我们想打印这样一条记录:

User:John has completed Action:payment at Time:13:30:00 

如果使用加号实现,会是下面这种形式:

print "User:" + user_name + " has completed Action:" + \ 
      action_name + " at Time:" + current_time

如果以后回过头来阅读这段代码,我们很难直观看出它的输出格式,且修改起来也相对麻烦。

我们可以换用 % 来实现:

print "User:%s has completed Action:%s at Time:%s" % \ 
    (user_name, action_name, current_time)

这回代码变得清晰简洁多了。

不过,Python 为我们提供了另一种简洁优雅的实现方式,也是官方更加推荐的方式:使用 str.format() 来实现字符串的格式化:

print "User:{} has completed Action:{} at Time:{}".format( 
    user_name, action_name, current_time)

str.format 既能够用于简单的场景,也能够胜任复杂的字符串替换,而无需繁琐的字符串连接操作。Python 的内置类型 str 和 unicode 均支持使用 str.format() 来格式化字符串。

我们接下来就详细地讨论 str.format() 的具体用法。

2. str.format 基本语法

格式化字符串使用花括号 {} 来包围替换字段,也就是待替换的字符串。而未被花括号包围的字符会原封不动地出现在结果中。

2.1. 使用位置索引

以下两种写法是等价的:

"Hello, {} and {}!".format("John", "Mary")

"Hello, {0} and {1}!".format("John", "Mary")

花括号内部可以写上目标字符串的索引,也可以省略。如果省略,则按 format 括号里的目标字符串顺序依次替换。

2.2. 使用关键字索引

除了通过位置来指定目标字符串,我们还可以通过关键字来指定它。

例如:

"Hello, {boy} and {girl}!".format(boy="John", girl="Mary")

使用关键字索引的好处是,我们无需关心参数的位置,且字符串的最终结果能够一目了然。在以后的代码维护中,我们能够快速地修改对应的参数,而不用对照字符串挨个去寻找相应的参数。

注意:如果字符串本身含有花括号,则需要将其重复两次来转义。例如,字符串本身含有 {,为了让 Python 知道这是一个普通字符,而不是用于包围替换字段的花括号,我们只需将它改写成 {{ 即可。

3. str.format 高级语法

str.format 非常强大,足以完成日常工作中遇到的格式化输出。熟练掌握该方法,能够为以后的字符串处理打好基础,还能节省不少时间。

3.1. 访问参数的属性或元素

在使用 str.format 来格式化字符串时,我们通常将目标字符串作为参数传递给 format 方法。实际上,我们还可以在格式化字符串中访问参数的某个属性或某个元素:

"My car is {0.color}.".format(black_car)
"The first student is {student[0]}.".format(student=stu_list)
"John is {d[john]} years old.".format(d=age_dict)

3.2. 参数输出转换

参数的字符串输出,默认是由其自身的 __format__ 方法来实现的。也就是说,Python 使用参数的 __format__ 输出来取代替换字段。如果我们想调用 str() 或 repr() 来转换参数,可以通过添加 转换标志 来实现:

# call str() on argument
"It's a {0!s}."

#call repr() on argument
"We can get info from {name!r}."

4. str.format 一般形式

格式化字符串的一般形式如下:

"... {field_name!conversion:format_spec} ..."

从上面的代码可以看到,格式化字符串可分为 field_name、conversion、format_spec 三部分,分别对应替换字段名称(索引)、转换标志、格式描述。其中,字段名称是必选的,而后两者是可选的。转换标志紧跟在英文感叹号后面,而格式描述紧跟在英文冒号后面。

前面已经提到过,字段名称既可是位置索引,也可是关键字索引。字段名称后面可以通过点来访问属性,或通过方括号来访问元素。

在这里,我们重点看一下格式描述(format_spec)这一项。

格式描述中含有6个选项,分别是 fill、align、sign、width、precision、type。 它们的位置关系如下:

[[fill]align][sign][#][0][width][,][.precision][type]
fill
可以是任意字符,默认为空格。

align
仅当指定最小宽度时有效。

< 左对齐(默认选项)
> 右对齐
= 仅对数字有效;将填充字符放到符号与数字间,例如 +0001234
^ 居中对齐
sign
仅对数字有效

+ 所有数字均带有符号
- 仅负数带有符号(默认选项)
 即空格;正数前面带空格,负数前面带符号
'#'
只对整数有效

自动在二进制、八进制、十六进制数值前添加对应的 0b、0o、 0x。

','
自动在每三个数字之间添加 , 分隔符。

width
十进制数字,定义最小宽度。如果未指定,则由内容的宽度来决定。

如果没有指定对齐方式(align),那么可以在 width 前面添加一个0来实现自动填充0,等价于 fill 设为 0 并且 align 设为 =。

precision
用于确定浮点数的精度,或字符串的最大长度。不可用于整型数值。

type
确定参数类型,默认为 s ,即字符串。

整数输出类型:

b:以二进制格式输出
c:将整数转换成对应的 unicode 字符
d:以十进制输出(默认选项)
o:以八进制输出
x:以十六进制小写输出
X:以十六进制大写输出
n:与 d 相同,但使用当前环境的分隔符来分隔每3位数字

十进制浮点数输出类型:

e:指数标记;使用科学计数法输出,用e来表示指数部分,默认 precision 为6
E:与 e 相同,但使用大写 E 来表示指数部分
f:以定点形式输出数值,默认 precision 为6
F:与 f 相同
g:通用格式;对于给定的 precision p >= 1,取数值的p位有效数字,并以定点或科学计数法输出(默认选项)
G:通用格式;与 g 相同,当数值过大时使用 E 来表示指数部分
n:与 g 相同,但使用当前环境的分隔符来分隔每3位数字
%:百分比标记;使用百分比的形式输出数值,同时设定 f 标记

Python 相关文章推荐
python实现ipsec开权限实例
Nov 11 Python
Python中函数的参数定义和可变参数用法实例分析
Jun 04 Python
Python中列表list以及list与数组array的相互转换实现方法
Sep 22 Python
解决python中os.listdir()函数读取文件夹下文件的乱序和排序问题
Oct 17 Python
Python字符串的常见操作实例小结
Apr 08 Python
python实现飞机大战游戏
Oct 26 Python
如何使用Python实现自动化水军评论
Jun 26 Python
python里运用私有属性和方法总结
Jul 08 Python
解决Pytorch 训练与测试时爆显存(out of memory)的问题
Aug 20 Python
python 列表推导式使用详解
Aug 29 Python
Python操作多维数组输出和矩阵运算示例
Nov 28 Python
使用python编写一个语音朗读闹钟功能的示例代码
Jul 14 Python
python中pandas.DataFrame对行与列求和及添加新行与列示例
Mar 12 #Python
Python中关键字nonlocal和global的声明与解析
Mar 12 #Python
Python中模块string.py详解
Mar 12 #Python
Python中第三方库Requests库的高级用法详解
Mar 12 #Python
python 获取网页编码方式实现代码
Mar 11 #Python
python 爬虫出现403禁止访问错误详解
Mar 11 #Python
Python如何读取MySQL数据库表数据
Mar 11 #Python
You might like
PHP中对用户身份认证实现两种方法
2011/06/04 PHP
PHP仿博客园 个人博客(2) 数据库增添改删
2013/07/05 PHP
php实现memcache缓存示例讲解
2013/12/04 PHP
php生成QRcode实例
2014/09/22 PHP
详解PHP中的mb_detect_encoding函数使用方法
2015/08/18 PHP
PHP排序算法之冒泡排序(Bubble Sort)实现方法详解
2018/04/20 PHP
PHP实现十进制数字与二十六进制字母串相互转换操作示例
2018/08/10 PHP
一个选择最快的服务器转向代码
2009/04/27 Javascript
jQuery 创建Dom元素
2010/05/07 Javascript
js截取固定长度的中英文字符的简单实例
2013/11/22 Javascript
浅析jquery的js图表组件highcharts
2014/03/06 Javascript
谷歌Chrome浏览器扩展程序开发小记
2016/01/06 Javascript
jQuery文字提示与图片提示效果实现方法
2016/07/04 Javascript
vue2.0学习之axios的封装与vuex介绍
2018/05/28 Javascript
React中如何引入Angular组件详解
2018/08/09 Javascript
elementUI select组件使用及注意事项详解
2019/05/29 Javascript
vue 插件的方法代码详解
2019/06/06 Javascript
微信小程序自定义tabbar custom-tab-bar 6s出不来解决方案(cover-view不兼容)
2019/11/01 Javascript
原生js实现点击轮播切换图片
2020/02/11 Javascript
[02:48]DOTA2英雄基础教程 拉席克
2013/12/12 DOTA
[00:13]天涯墨客二技能展示
2018/08/25 DOTA
[01:18:35]DOTA2-DPC中国联赛 正赛 Elephant vs LBZS BO3 第一场 1月29日
2021/03/11 DOTA
python日期相关操作实例小结
2019/06/24 Python
python xlwt如何设置单元格的自定义背景颜色
2019/09/03 Python
Python 转换RGB颜色值的示例代码
2019/10/13 Python
python代码如何实现余弦相似性计算
2020/02/09 Python
StubHub哥伦比亚:购买和出售您的门票
2016/10/20 全球购物
传统软件工程与面向对象的软件工程有什么区别
2012/05/31 面试题
人事主管的岗位职责
2013/11/16 职场文书
毕业生简单求职信
2013/11/19 职场文书
证券期货行业个人的自我评价
2013/12/26 职场文书
先进个人申报材料
2014/12/30 职场文书
个人年终总结范文
2015/03/09 职场文书
南阳市白酒市场的调查报告
2019/11/08 职场文书
Python使用UDP实现720p视频传输的操作
2021/04/24 Python
Nginx文件已经存在全局反向代理问题排查记录
2022/07/15 Servers