Python 使用习惯是指那些经常被使用的语法、语义和结构,这样写更加符合 Python 风格(pythonic),看起来更像一个地道的 Pythonista.
1. if not x
直接使用 x 和 not x 判断 x 是否为 None 或空
x = [1,3,5]
if x:
print('x is not empty ')
if not x:
print('x is empty')
2. enumerate 枚举
直接使用 enumerate 枚举容器,第二个参数表示索引的起始值
x = [1, 3, 5]
for i, e in enumerate(x, 10): # 枚举
print(i, e)
10 1
11 3
12 5
3. in
x = 'zen_of_python'
if 'zen' in x:
print('zen is in')
4 zip 打包
keys = ['a', 'b', 'c']
values = [1, 3, 5]
for k, v in zip(keys, values):
print(k, v)
a 1
b 3
c 5
5 一对 '''
print('''"Oh no!" He exclaimed.
"It's the blemange!"''')
6 交换元素
直接解包赋值,更加符合 Python 风格:
a, b = 1, 3
a, b = b, a # 交换a,b
7 join 串联
串联字符串,更习惯使用 join:
chars = ['P', 'y', 't', 'h', 'o', 'n']
name = ''.join(chars)
print(name)
'Python'
8 列表生成式
列表生成式构建高效,符合 Python 习惯:
data = [1, 2, 3, 5, 8]
result = [i * 2 for i in data if i & 1] # 奇数则乘以2
print(result) # [2, 6, 10]
9 字典生成式
除了列表生成式,还有字典生成式:
keys = ['a', 'b', 'c']
values = [1, 3, 5]
d = {k: v for k, v in zip(keys, values)}
print(d)
{'a': 1, 'b': 3, 'c': 5}
10 name == 'main'有啥用
曾几何时,看着别人代码这么写,我们也就跟着这么用吧,其实还没有完全弄清楚这行到底干啥。
def mymain():
print('Doing something in module', __name__)
if __name__ == '__main__':
print('Executed from command line')
mymain()
加入上面脚本命名为 MyModule,不管在 vscode 还是 pycharm 直接启动,则直接打印出:
Executed from command line
Doing something in module __main__
这并不奇怪,和我们预想一样,因为有无这句 main ,都会打印出这些。
但是当我们 import MyModule 时,如果没有这句,直接就打印出:
In [2]: import MyModule
Executed from command line
Doing something in module MyModule
只是导入就直接执行 mymain 函数,这不符合我们预期。
如果有主句,导入后符合预期:
In [6]: import MyModule
In [7]: MyModule.mymain()
Doing something in module MyModule
网友评论