当前位置: 移动技术网 > IT编程>脚本编程>Python > 跟老齐学Python之从格式化表达式到方法

跟老齐学Python之从格式化表达式到方法

2019年03月26日  | 移动技术网IT编程  | 我要评论

容县公社论坛,夕阳之约老头图片,仙境传说单机版下载

现在我们就格式化方法做一个详细一点的交代。

基本的操作

所谓格式化方法,就是可以先建立一个输出字符串的模板,然后用format来填充模板的内容。

复制代码 代码如下:

>>> #先做一个字符串模板
>>> template = "my name is {0}. my website is {1}. i am writing {2}."

>>> #用format依次对应模板中的序号内容
>>> template.format("qiwsir","qiwsir.github.io","python")
'my name is qiwsir. my website is qiwsir.github.io. i am writing python.'

当然,上面的操作如果你要这样做,也是可以的:

复制代码 代码如下:

>>> "my name is {0}. my website is {1}. i am writing {2}.".format("qiwsir","qiwsir.github.io","python")
'my name is qiwsir. my website is qiwsir.github.io. i am writing python.'

这些,跟用%写的表达式没有什么太大的区别。不过看官别着急,一般小孩子都区别不到,长大了才有区别的。慢慢看,慢慢实验。

除了可以按照对应顺序(类似占位符了)填充模板中的位置之外,还能这样,用关键字来指明所应该田中的内容。

复制代码 代码如下:

>>> template = "my name is {name}. my website is {site}"
>>> template.format(site='qiwsir.github.io', name='qiwsir')
'my name is qiwsir. my website is qiwsir.github.io'

关键词所指定的内容,也不一定非是str,其它的数据类型也可以。此外,关键词和前面的位置编号,还可以混用。比如:

复制代码 代码如下:

>>> "{number} is in {all}. {0} are my number.".format("seven",number=7,all=[1,2,3,4,5,6,7,8,9,0])
'7 is in [1, 2, 3, 4, 5, 6, 7, 8, 9, 0]. seven are my number.'

是不是开始感觉有点意思了?看输出结果,就知道,经过format方法得到是一个新的str。

序列对象的偏移量

有这样一个要求:在输出中,显示出一个单词的第一个字母和第三个个字母。比如单词python,要告诉看官,第一字母是p,第三个字母是t。

这个问题并不难。实现方法也不少,这里主要是要展示一下偏移量在format中的应用。

复制代码 代码如下:

>>> template = "first={0[0]}, third={0[2]}"
>>> template.format(word)
'first=p, third=t'

list也是序列类型的,其偏移量也可。

复制代码 代码如下:

>>> word_lst = list(word)
>>> word_lst
['p', 'y', 't', 'h', 'o', 'n']
>>> template
'first={0[0]}, third={0[2]}'
>>> template.format(word_lst)
'first=p, third=t'

对上面的综合一下,稍微啰嗦一点的实验:

复制代码 代码如下:

>>> template = "the word is {0}, its first is {0[0]}. another word is {1}, its second is {1[1]}."
>>> template.format("python","learn")
'the word is python, its first is p. another word is learn, its second is e.'

>>> "{name}\'s first is {name[0]}".format(name="qiwsir")    #指定关键词的值的偏移量
"qiwsir's first is q"

值得注意的是,偏移量在序列类型的数据中,因为可以是负数,即能够从右边开始计数。

复制代码 代码如下:

>>> word
'python'
>>> word[-1]
'n'
>>> word[-2]
'o'

但是,在模板中,无法使用负数的偏移量。

复制代码 代码如下:

>>> "first={0[0]}, end={0[-1]}".format(word) #报错
traceback (most recent call last):
  file "<stdin>", line 1, in <module>
typeerror: string indices must be integers, not str

>>> "first={0[0]}, end={0[5]}".format(word)  #把-1改为5就可以了。
'first=p, end=n'

当然,放到模板外面是完全可行的。这样就好了:

复制代码 代码如下:

>>> "first={0}, end={1}".format(word[0],word[-1])
'first=p, end=n'

dictionary的键

直接上实验,先观察,再得结论

复制代码 代码如下:

>>> myinfo
{'website': 'qiwsir.github.io', 'name': 'qiwsir', 'room': 703}
>>> template = "i am {0[name]}"
>>> template.format(myinfo)
'i am qiwsir'
>>> template = "i am {0[name]}. my qq is {qq}"
>>> template.format(myinfo,qq="26066913")
'i am qiwsir. my qq is 26066913'

位置后面跟键,就能得到format的参数中字典的键对应的值。太罗嗦了吧,看例子就明白了。出了根据位置得到,还能够根据关键词得到:

复制代码 代码如下:

>>> myinfo
{'website': 'qiwsir.github.io', 'name': 'qiwsir', 'room': 703}
>>> "my website is {info[website]}, and i like {0}".format("python",info=myinfo)    #关键词info引用的是一个字典
'my website is qiwsir.github.io, and i like python'

模板中添加属性

看标题不懂在说什么。那就看实验吧。

复制代码 代码如下:

>>> import math
>>> "pi is {pi.pi}".format(pi=math)
'pi is 3.14159265359'

这是用关键词,下面换个稍微复杂点,用位置的。

复制代码 代码如下:

>>> import sys,math
>>> 'pi is {0.pi}. my lptop runs {1.platform}'.format(math,sys)
'pi is 3.14159265359. my lptop runs linux2'

看官理解了吧。

其它进制

在这个世界上的数学领域,除了有我们常常用到的十进制、十二进制(几点了,这是你我常用到的,钟表面就是12进制)、六十进制(这个你也熟悉的)外,还有别的进制,比如二进制、八进制、十六进制等等。此处不谈进制问题,有兴趣详细了解,请各自google。不过,进制的确在计算机上很重要的。因为机器在最底层是用二进制的。

这里只是说明一下输出时候的进制问题。

>>> "{0:x}, {1:o}, {2:b}".format(255,255,255)
'ff, 377, 11111111'
x:十六进制,hex
o:八进制,octal
b:二进制,binary
顺便补充,对于数的格式化方法输出和格式化表达式一样,就不赘述了。

在格式化方法中,还能够指定字符宽度,左右对齐等简单排版格式,不过,在我的经验中,这些似乎用的不怎么多。如果看官需要,可以google或者到官方文档看看即可。

关于格式化表达式和格式化方法,有的人进行了不少比较,有的人说用这个,有的人倾向用那个。我的建议是,你用哪个顺手就用哪个。切忌门派之见呀。不过,有人传说格式化表达式可能在将来某个版本中废除。那是将来的事情,将来再说好了。现在,你就捡着顺手的用吧。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网