python格式化字符串format_Python 中格式化字符串 % 和 format 两种方法之间的区别

Python2.6引入了 format 格式化字符串的方法,现在格式化字符串有两种方法,就是 % 和 format ,具体这两种方法有什么区别呢?请看以下解析。

# 定义一个坐标值

c = (250, 250)

# 使用%来格式化

s1 = "敌人坐标:%s" % c

上面的代码很明显会抛出一个如下的TypeError:

TypeError: not all arguments converted during string formatting

像这类格式化的需求我们需要写成下面丑陋的格式才行:

# 定义一个坐标值

c = (250, 250)

# 使用%丑陋的格式化...

s1 = "敌人坐标:%s" % (c,)

而使用 format 就不会存在上面的问题:

# 定义一个坐标值

c = (250, 250)

# 使用format格式化

s2 = "敌人坐标:{}".format(c)

一般情况下,使用 % 已经足够满足我们的需求,但是像这种一个位置需要添加元素或列表类型的,就最好选择 format 方法。

新特性

在Python3.6中加入了f-strings:

In[1]: name = "Q1mi"

In[2]: age = 18

In[3]: f"My name is {name}.I'm {age}"

Out[3]: "My name is Q1mi.I'm 18"

format 的常用方法

通过位置(索引)

In[1]: data = ["Q1mi", 18]

In[2]: "Name:{0}, Age:{1}".format(*data)

Out[2]: 'Name:Q1mi, Age:18'

通过关键字

In[1]: data = {"name": "Q1mi", "age": 18}

In[2]: "Name:{name}, Age:{age}".format(**data)

Out[2]: 'Name:Q1mi, Age:18'

通过对象属性

In[1]: class Person(object):

...: def __init__(self, name, age):

...: self.name = name

...: self.age = age

...: def __str__(self):

...: return "This guy is {self.name}, {self.age} years old.".format(self=self)

...:

In[2]: p = Person("Q1mi", 18)

In[3]: str(p)

Out[3]: 'This guy is Q1mi, 18 years old.'

通过下标

In[1]: "{0[0]} is {0[1]} years old.".format(data)

Out[1]: 'Q1mi is 18 years old.'

填充与对齐

填充常跟对齐一起使用

^ < > 分别是居中、左对齐、右对齐,后面带宽度。

:号后面带填充的字符,只能是一个字符,不指定的话默认是用空格填充。

In[1]: "{:>10}".format('')

Out[1]: ''

In[2]: "{:0>10}".format('')

Out[2]: ''

In[3]: "{:A>10}".format('')

Out[3]: 'AAAAAAAA18

补充一个字符串自带的 zfill() 方法:

Python zfill() 方法返回指定长度的字符串,原字符串右对齐,前面填充 0.

zfill() 方法语法:str.zfill(width)

参数width指定字符串的长度。原字符串右对齐,前面填充0

返回指定长度的字符串

In[1]: "{:.2f}".format(3.1415926)

Out[1]: '3.14'

精度与类型f

精度常跟类型f一起使用。

In[1]: "{:.2f}".format(3.1415926)

Out[1]: '3.14'

其中.2表示长度为2的精度,f表示float类型。

其他进制

b d o x 分别是二进制,十进制,八进制,十六进制。

In[1]: "{:b}".format(18)

Out[1]: ''

In[2]: "{:d}".format(18)

Out[2]: ''

In[3]: "{:o}".format(18)

Out[3]: ''

In[4]: "{:x}".format(18)

Out[4]: ''

千位分隔符

In[1]: "{:,}".format(1234567890)

Out[1]: '1,234,567,890'

SERVLET中的doGet与doPost两个方法之间的区别

get和post是http协议的两种方法,另外还有head, delete等 这两种方法有本质的区别,get只有一个流,参数附加在url后,大小个数有严格限制且只能是字符串.post的参数是通过另外的 ...

table中超长字符串省略号表示两种方法

写在前面:   1.第一种从网上找到的解决方式添加table-layout:fixed   2.第二种添加div   3.字符串过长产生省略号的css语句为如下三种合用:overflow:hidden ...

Python中执行系统命令常见的几种方法--转载

Python中执行系统命令常见的几种方法 Python中执行系统命令常见的几种方法有: (1)os.system # 仅仅在一个子终端运行系统命令,而不能获取命令执行后的返回信息 # 如果再命令行下执 ...

&period;net中创建xml文件的两种方法

.net中创建xml文件的两种方法 方法1:根据xml结构一步一步构建xml文档,保存文件(动态方式) 方法2:直接加载xml结构,保存文件(固定方式) 方法1:动态创建xml文档 根据传递的值,构建 ...

在Delphi中使用C&plus;&plus;对象(两种方法,但都要改造C&plus;&plus;提供的DLL)

Delphi是市场上最好的RAD工具,但是现在C++占据着主导地位,有时针对一个问题很难找到Delphi或Pascal的解决方案.可是却可能找到了一个相关的C++类.本文描述几种在Delphi代码中使 ...

Js 字符串拼接的两种方法

字符串拼接的两种方法 用数组的方法的好处是:避免变量重新定义.赋值

&lpar;转&rpar;Shell中获取字符串长度的七种方法

Shell中获取字符串长度的七种方法 原文:http://blog.csdn.net/jerry_1126/article/details/51835119 求字符串操作在shell脚本中很常用,下面 ...

golang中获取字符串长度的几种方法

一.获取字符串长度的几种方法   - 使用 bytes.Count() 统计   - 使用 strings.Count() 统计   - 将字符串转换为 []rune 后调用 len 函数进行统计   ...

在shell script中进行数值运算的两种方法

方法1:使用"$((计算式))"的方式进行数值运算,不需要使用declare命令显示声明数值型变量来存储计算结果: 方法2:使用declare命令配合"-i"选 ...

随机推荐

vue 组建实现数据的双向绑定

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值