if语句
Python if语句是选取要执行的操作。
通用格式
if :
elif :
else:
Python语法规则
Python语法特性
- 语句是逐个运行的
- 块和语句的边界会自动检测。
- 复合语句=首行+“:”+缩进语句。Python中所有复合语句都遵循相同格式:首行会以冒号终止,再接一个或多个嵌套语句。通常都是在首行下缩进的。
- 空白行、空格以及注释通常都会忽略。
- 文档字符串会被忽略
代码块分隔符
Python会自动以行缩进检测块的边界,也就是程序代码左侧的空白空间。缩进至右侧相同距离的所有语句属于同一块的代码。块内的代码会垂直对齐。更深层的嵌套块就是比所在块的语句进一步向右缩进
在Python中尽管可以使用空格或制表符来缩进,在一段代码块中混合使用这两者通常不是好主意。
if/else三元表达式
在Python2.5中引入了新的表达式格式
A= Y of X else Z
只有当X为真才会执行表达式Y,当X为假,才会执行表达式Z
循环计数器range
range函数是通用的工具,可用在各种环境下,range可以产生一个固定顺序的索引
>>> list(range(5))
[0, 1, 2, 3, 4]
>>> list(range(2,5))
[2, 3, 4]
>>> list(range(0,10,2))
[0, 2, 4, 6, 8]
- range中有一个参数时range会产生从零算起的整数列表,其中不包括该参数的值
- range中有两个参数时,第一个参数将视为下边界。
- range中有三个参数时,Python会对每个连续整数加上步进值从而得到结果
range()常用来间接的迭代一个序列。与for循环结合后的执行速度是十分快的
>>> for i in range(3):
... print(i,'pythons')
...
0 pythons
1 pythons
2 pythons
并行遍历语句:zip
- zip会取得一个或多个序列为参数,然后返回元组的列表。将这些序列中的并排的元素配成对
>>> L1=[1,2,3,4,5]
>>> L2=[2,3,4,5,6]
>>> print(zip(L1,L2))
>>> print(list(zip(L1,L2)))
[(1, 2), (2, 3), (3, 4), (4, 5), (5, 6)]
>>> L2=[2,3,4,5]
>>> print(list(zip(L1,L2)))
[(1, 2), (2, 3), (3, 4), (4, 5)]
>>> print(tuple(zip(L1,L2)))
((1, 2), (2, 3), (3, 4), (4, 5))
- zip返回的是一个元组对象
- zip接收任何类型的序列(可迭代对象,可以是文件)
- zip可以有两个以上的参数
- 在参数长度不同时,zip会以最短序列的长度为准来截断所得到的元组
>>> S1='abc'
>>> S2='xyz123'
>>> tuple(zip(S1,S2))
(('a', 'x'), ('b', 'y'), ('c', 'z'))
使用zip构造字典
- Python2.2之前的版本
>>> keys=['a','b','c','d']
>>> vals=[1,3,5,7]
>>> dict_a = {}
>>> for k,v in zip(keys,vals):
... dict_a[k]=v
...
>>> print(dict_a)
{'a': 1, 'b': 3, 'c': 5, 'd': 7}
- Python2.2后可以直接使用字典的构造函数dict
>>> keys=['spam','eggs','toast']
>>> vals=[1,2,3]
>>> D=dict(zip(keys,vals))
>>> D
{'spam': 1, 'eggs': 2, 'toast': 3}
产生偏移元素enumerate
enumerate函数会返回一个生成器对象:这种对象支持迭代协议,可以得到偏移值的计数器
>>> s= 'SPAM'
>>> for (offset,item) in enumerate(s):
... print(item,offset)
...
S 0
P 1
A 2
M 3