python format函数的用法是什么呢?不知道的小伙伴来看看小编今天的分享吧!
python format函数用法详解:
1、位置
print("hello {0}, this is {1}.".format("world", "python")) # 根据位置下标进行填充
print("hello {}, this is {}.".format("world", "python")) # 根据顺序自动填充
print("hello {0}, this is {1}. {1} is a new language.".format("world", "python")) # 同一参数可以填充多次
输出:
hello world, this is python.
hello world, this is python.
hello world, this is python. python is a new language.
2、key
obj = "world"
name = "python"
print("hello {obj}, this is {name}.".format(obj = obj, name = name))
输出:
hello world, this is python.
3、列表
list = ["world", "python"]
print("hello {names[0]}, this is {names[1]}.".format(names = list))
输出:
hello world, this is python.
4、字典
dict = {"obj":"world", "name":"python"}
print("hello {names[obj]}, this is {names[name]}.".format(names = dict))
输出:
hello world, this is python.
注意:
访问字典的 key,不用引号。
5、类属性
class Names():
obj = "world"
name = "python"
print("hello {names.obj}, this is {names.name}.".format(names = Names))
输出:
hello world, this is python.
6、魔法参数
args = [",", "inx"]
kwargs = {"obj": "world", "name": "python"}
print("hello {obj}{} this is {name}.".format(*args, **kwargs))
输出:
hello world, this is python.
注意:
这里的 format(*args, **kwargs) 等价于 format(",", "inx", obj = "world", name = "python")。
二、数字格式化
三、其他用法
1、转义
print("{{hello}} {{{0}}}".format("world"))
输出:
{hello} {world}
2、format 作为函数变量
name = "python"
hello = "hello, welcome to {} world!".format
print(hello(name))
输出:
hello, welcome to python world!
3、格式化 datatime
from datetime import datetime
now = datetime.now()
print("{:%Y-%m-%d %X}".format(now))
输出:
2020-12-15 19:46:24
4、{}内嵌{}
print("hello {0:>{1}} ".format("world", 10))
输出:
hello world
以上就是小编今天的分享了,希望可以帮助到大家。
Python 字符串格式化(format)介绍
本文将通过string的format函数,介绍在Python中格式化字符串的几种常用方法。
以下是我们的源代码:
程序的执行效果如下:
下面我们将逐行解释一下。
第1行:这是format的基本用法。基于传入参数的位置,我们使用花括号来将对应的参数替换到format的字符串上。比如第1个参数我们传入了"成都",第2个参数我们传入了34。因此,在字符串中,程序第1次遇到花括号时,就将"成都"替换上去,第2次遇到花括号时,将34替换上去。
第2行和第3行:我们在花括号中加入了数字,这样就可以自由的控制传入的参数。比如这次,我们第1个参数传入string形式的分行名称,第2个参数传入number形式的余额时,我们可以使用{0}来引用分行名称,用{1}来引用余额。在某些使用场景下,我们可能引用的顺序和参数传入的顺序会不同。比如第3行,我们对调了传入参数的顺序,我们先传入37,再传入"大连",而引用时,我们就可以直接使用{1}来引用第2个参数即"大连"来替换这个字符串。这在参数较多或需要重复引用的时候就很方便,试想一下我们有七八个参数,又或是比如分行名称可能在两个地方都要用,那我们就可以在每个需要分行名称的地方,都使用{1}替换一次,这就方便多了,要不然我们就得在传入的参数列表上多次敲好多遍变量名称。
第4行:我们使用了关键字参数。传入参数时指定了关键字参数之后,在使用时,我们可以用{name}的形式直接引用,如果只是使用基于位置的参数,那么参数多了会看不出来到底引用了哪个参数,容易出BUG(想想七八个参数,看字符串含义的时候,估计你就得回去数一下{5}是指谁?),但是如果使用了关键字参数,就可以顾名思义,直观的看出整个语句的含义。大家回过头看一下第4行的print是不是就比之前的例子,要容易理解一些。
第5行:当然,我们也可以将基于位置的参数和关键字参数相结合。就像第5行演示的一样。第1和第2个参数是基于位置的。使用{0}和{1}引用,而第3个参数是使用关键字参数引用。这里大家要注意,关键字参数要位于基于位置的参数后面。
好了,下面我们看两个比较复杂的例子。
第6行:我们在参数上使用了字典(dict)变量。这时我们使用类似{0[name]}的形式,引用了这个字典变量。花括号后面的0,代表是基于位置的第1个参数,而由于参数是字典类型,所以再使用方括号加名称,即[name],就可以引用数据了。其实也有点儿类似我们平常用dict[name]的形式引用数据。
第7行:在上面的例子中,我们虽然可以引用字典类型变量了,但是{0[name]}这种玩意儿,还是太丑陋了。因此我们可以使用"**"符号来解压参数。经过**ind_chengdu之后,我们在字符串中引用参数时,就可以改为{name}这样的形式,这样整个字符串的展示就很亲民了,我们也很容易看出整个字符串的含义。现在的效果也比较接近第4行的例子。
这里有一个小问题,大家要关注一下,就是使用**解压参数时,实参(即传入的参数)需要位于参数列表最后一个,所以第第6行相比,我们把传入参数的位置调换了一下。
以上就是关于Python中字符串格式化的一些技巧,希望对大家有所帮助。
我使用的环境:Windows 7 Python 2.7.17 PyCharm Community Edition 2016.1.5
如果大家认为我的文章还可以,真心希望能帮我点一个"关注",粉丝的数量真的对我很重要,也算是对我努力结果的一个支持,谢谢大家了。