深入Python(二)

变量声明

Python 与大多数其它语言一样有局部变量和全局变量之分,但是它没有明显的变量声明。变量通过首次赋值产生,当超出作用范围时自动消亡。

一次赋多值

Python 中比较 “酷” 的一种编程简写是使用序列来一次给多个变量赋值

>>> v = ('a', 'b', 'e')

>>> (x, y, z) = v     

>>> x

'a'

>>> y

'b'

>>> z

'e'

v 是一个三元素的 tuple,并且 (x, y, z) 是一个三变量的 tuple。将一个 tuple 赋值给另一个 tuple,会按顺序将 v 的每个值赋值给每个变量

连续值赋值

>>> (a,b,c,d)=range(4)

>>> a

0

>>> b

1

>>> c

2

>>> d

3

内置的 range 函数返回一个元素为整数的 list。这个函数的简化调用形式是接收一个上限值,然后返回一个初始值从 0 开始的 list,它依次递增,直到但不包含上限值。

如果您愿意,您可以传入其它的参数来指定一个非 0 的初始值和非 1 的步长

>>> (a,b,c,d)=range(2,9,2)

>>> a

2

>>> b

4

>>> c

6

>>> d

8

一定要确保range返回的list里的元素数量大于等于变量元组里的元素数量


格式化字符串

在 Python 中,字符串格式化使用与 C 中 printf 函数一样的语法

字符串格式化不只是连接。它甚至不仅仅是格式化。它也是强制类型转换

>>> uid = "sa"

>>> pwd = "secret"

>>> print pwd + " is not a good password for " + uid      

secret is not a good password for sa

>>> print "%s is not a good password for %s" % (pwd, uid) 

secret is not a good password for sa

>>> userCount = 6

>>> print "Users connected: %d" % (userCount, )       字符串格式化通过将 %s 替换成 %d 即可处理整数      

Users connected: 6

>>> print "Users connected: " + userCount                 

Traceback (innermost last):

  File "<interactive input>", line 1, in ?

TypeError: cannot concatenate 'str' and 'int' objects

数值的格式化

>>> print "Today's stock price: %f" % 50.4625   

50.462500

>>> print "Today's stock price: %.2f" % 50.4625 

50.46

>>> print "Change since yesterday: %+.2f" % 1.5 

+1.50

%f 格式符选项对应一个十进制浮点数,不指定精度时打印 6 位小数。

使用包含“.2”精度修正符的 %f 格式符选项将只打印 2 位小数。

添加 + 修正符用于在数值之前显示一个正号或负号。注意“.2”精度修正符仍旧在它原来的位置,用于只打印 2 位小数。


映射list

>>> li = [1, 9, 8, 4]

>>> [elem*2 for elem in li]      

[2, 18, 16, 8]

Python 循环遍历 li 中的每个元素。对每个元素均执行如下操作:首先临时将其值赋给变量 elem,然后 Python 应用函数 elem*2 进行计算,最后将计算结果追加到要返回的 list 中,Python 会在内存中创建新的 list,当对 list 的解析完成时,Python 将结果赋给变量。此理中原li不会受到影响。

Dictionary 的keys, values 和 items 函数

>>> params = {"server":"mpilgrim", "database":"master", "uid":"sa", "pwd":"secret"}

>>> params.keys()        Dictionary 的 keys 方法返回一个包含所有键的 list      这个 list 没按 dictionary 定义的顺序输出 (记住,元素在 dictionary 中是无序的)

['server', 'uid', 'database', 'pwd']

>>> params.values()     values 方法返回一个包含所有值的 list

['mpilgrim', 'sa', 'master', 'secret']

>>> params.items()        items 方法返回一个由形如 (keyvalue) 组成的 tuple 的 list

[('server', 'mpilgrim'), ('uid', 'sa'), ('database', 'master'), ('pwd', 'secret')]


>>> params = {"server":"mpilgrim", "database":"master", "uid":"sa", "pwd":"secret"}

>>> params.items()

[('server', 'mpilgrim'), ('uid', 'sa'), ('database', 'master'), ('pwd', 'secret')]

>>> [k for k, v in params.items()]                

['server', 'uid', 'database', 'pwd']

>>> [v for k, v in params.items()]                

['mpilgrim', 'sa', 'master', 'secret']

>>> ["%s=%s" % (k, v) for k, v in params.items()] 

['server=mpilgrim', 'uid=sa', 'database=master', 'pwd=secret']

请注意我们正在使用两个变量对 list params.items() 进行遍历。这是多变量赋值的另一种用法。

params.items() 的第一个元素是 ('server', 'mpilgrim'),所以在 list 解析的第一次遍历中,k 将为 'server',v 将为 'mpilgrim'。在本例中,我们忽略了返回 list 中 v 的值,而只包含了 k 的值,所以这个 list 解析最后等于 params.keys()。

连接list与分割字符串

>>> params = {"server":"mpilgrim", "database":"master", "uid":"sa", "pwd":"secret"}

>>> ["%s=%s" % (k, v) for k, v in params.items()]

['server=mpilgrim', 'uid=sa', 'database=master', 'pwd=secret']

>>> ";".join(["%s=%s" % (k, v) for k, v in params.items()])

'server=mpilgrim;uid=sa;database=master;pwd=secret'

join 方法将 list 中的元素连接成单个字符串,每个元素用一个分号隔开。join 只能用于元素是字符串的 list;它不进行任何的强制类型转换。连接一个存在一个或多个非字符串元素的 list 将引发一个异常。

>>>s='server=mpilgrim;uid=sa;database=master;pwd=secret'

>>> s.split(";")

['server=mpilgrim', 'uid=sa', 'database=master', 'pwd=secret']

split 与 join 正好相反,它将一个字符串分割成多元素 list

split 接受一个可选的第二个参数,它是要分割的次数

>>> s.split(";", 1) 

['server=mpilgrim', 'uid=sa;database=master;pwd=secret']

posted @ 2011-07-24 22:51  何塞穆里尼奥  阅读(634)  评论(4编辑  收藏  举报