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自带的http模块详解
Nov 06 Python
Python 实现简单的shell sed替换功能(实例讲解)
Sep 29 Python
Python内置函数 next的具体使用方法
Nov 24 Python
Python实现读取及写入csv文件的方法示例
Jan 12 Python
python实现txt文件格式转换为arff格式
May 31 Python
python处理multipart/form-data的请求方法
Dec 26 Python
Python编程在flask中模拟进行Restful的CRUD操作
Dec 28 Python
Python面向对象程序设计类变量与成员变量、类方法与成员方法用法分析
Apr 12 Python
打包python 加icon 去掉cmd黑窗口方法
Jun 24 Python
Python操作Sonqube API获取检测结果并打印过程解析
Nov 27 Python
利用Pycharm + Django搭建一个简单Python Web项目的步骤
Oct 22 Python
PyCharm2020.3.2安装超详细教程
Feb 08 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堆栈与列队的学习
2013/06/21 PHP
PHP实现多图片上传类实例
2014/07/26 PHP
Yii2 ActiveRecord多表关联及多表关联搜索的实现
2016/06/30 PHP
PHP连接及操作PostgreSQL数据库的方法详解
2019/01/30 PHP
用jquery ajax获取网站Alexa排名的代码
2009/12/12 Javascript
JavaScript 数组循环引起的思考
2010/01/01 Javascript
JavaScript.The.Good.Parts阅读笔记(二)作用域&amp;闭包&amp;减缓全局空间污染
2010/11/16 Javascript
Javascript中的isNaN函数使用说明
2011/11/10 Javascript
使用text方法获取Html元素文本信息示例
2014/09/01 Javascript
JavaScript使用ActiveXObject访问Access和SQL Server数据库
2015/04/02 Javascript
js实现兼容IE和FF的上下层的移动
2015/05/04 Javascript
JavaScript中判断两个字符串是否相等的方法
2015/07/07 Javascript
JavaScript中Date对象的常用方法示例
2015/10/24 Javascript
javascript中的作用域和闭包详解
2016/01/13 Javascript
js获取html的span标签的值方法(超简单)
2016/07/26 Javascript
利用SpringMVC过滤器解决vue跨域请求的问题
2018/02/10 Javascript
JavaScript动态添加数据到表单并提交的几种方式
2019/06/26 Javascript
[02:49]2014DOTA2电竞也是体育项目! 势要把荣誉带回中国!
2014/07/20 DOTA
PYTHON基础-时间日期处理小结
2018/05/05 Python
在cmd中运行.py文件: python的操作步骤
2018/05/12 Python
postman模拟访问具有Session的post请求方法
2019/07/15 Python
Python测试模块doctest使用解析
2019/08/10 Python
flask/django 动态查询表结构相同表名不同数据的Model实现方法
2019/08/29 Python
Django框架model模型对象验证实现方法分析
2019/10/02 Python
Python 读取WAV音频文件 画频谱的实例
2020/03/14 Python
aec加密 php_php aes加密解密类(兼容php5、php7)
2021/03/14 PHP
收集的7个CSS3代码生成工具
2010/04/17 HTML / CSS
找到不普通的东西:Bonanza
2016/10/20 全球购物
NFL加拿大官方网上商店:NHLShop.ca
2019/03/12 全球购物
副校长竞聘演讲稿
2014/09/01 职场文书
入党介绍人考察意见
2015/06/01 职场文书
消费者理赔投诉书
2015/07/02 职场文书
六一儿童节致辞
2015/07/31 职场文书
2016年感恩父亲节活动总结
2016/04/01 职场文书
python3.7.2 tkinter entry框限定输入数字的操作
2021/05/22 Python
CSS实现隐藏搜索框功能(动画正反向序列)
2021/07/21 HTML / CSS