本文旨在收集記錄分享簡(jiǎn)潔漂亮的Python寫法,歡迎補(bǔ)充
字典/集合推導(dǎo)式(dict/set comprehension)
類似于列表推導(dǎo)式:
my_dict = {i: i * i for i in xrange(100)}
my_set = {i * 15 for i in xrange(100)}
#這倆在寫法上的區(qū)別只是字典推導(dǎo)式多了一個(gè)':'
Caution:
區(qū)別一下三種寫法:
>>>my_set={i*15 for i in xrange(100)}
>>>my_list=[i*15 for i in xrange(100)]
>>>my_generator=(i*15 for i in xrange(100))
>>>print "my_set", type(my_set)
my_set <type 'set'>
>>>print "my_list", type(my_list)
my_list <type 'list'>
>>>print "my_generator", type(my_generator)
my_generator <type 'generator'>
枚舉 (enumerate)
要在枚舉過程中使用序號(hào)令野,可以使用enumerate
優(yōu)雅地實(shí)現(xiàn):
#i從0開始,每次加1
for i, item in enumerate(iterable):
print i, item
#i從2開始
for i, item in enumerate(iterable, 2):
print i, item
強(qiáng)制浮點(diǎn)數(shù)除法
如果我們對(duì)兩個(gè)整數(shù)做/
除法,Python 2 返回的是一個(gè)整數(shù)求厕,如需返回浮點(diǎn)數(shù)的結(jié)果桶至,在Python 2.x中通常會(huì)這么做:
>>>1.0/2
0.5
可以這樣更漂亮地實(shí)現(xiàn):
>>>from __future__ import division
>>>1/2
0.5
而在Python 3中晾匠,/
是真除赠叼,默認(rèn)精確到小數(shù)點(diǎn)后一位擦囊。
使用literal_eval()
我們都知道eval:
expr = "[1, 2, 3]"
my_list = eval(expr)
但估計(jì)沒幾個(gè)人知道literal_eval( ):
import ast
my_list = ast.literal_eval(expr)
(看起來好像并沒有變漂亮呢,但ast.literal_eval()更安全嘴办。)
用dir( )查看一個(gè)Python對(duì)象
>>> foo = [1, 2, 3, 4]
>>> dir(foo)
['__add__', '__class__', '__contains__',
'__delattr__', '__delitem__', '__delslice__', ... ,
'extend', 'index', 'insert', 'pop', 'remove',
'reverse', 'sort']
調(diào)試腳本
利用pdb模塊可以輕松地在腳本中設(shè)置斷點(diǎn):
import pdb
pdb.set_trace()
你可以在腳本的任何位置加上pdb.set_trace()來設(shè)置斷點(diǎn)。
簡(jiǎn)化if 結(jié)構(gòu)
當(dāng)有多個(gè)值需要檢驗(yàn)的時(shí)候买鸽,通常會(huì)這么寫:
if n==1 or n==4 or n==5 or n==6:
更漂亮的寫法是:
if n in [1,4,5,6]:
反轉(zhuǎn)列表/字符串
你可以這樣快速地反轉(zhuǎn)一個(gè)列表:
>>>a=[1,2,3]
>>>a[::-1]
[3,2,1]
這樣會(huì)生成一個(gè)新的列表涧郊,原列表不會(huì)變。如果你想在原地反轉(zhuǎn)列表眼五,可以這樣:
>>> a.reverse()
>>> a
[3, 2, 1]
字符串類型string是不可變類型妆艘,因此也就沒有reverse( )咯。
行內(nèi)if 聲明
a=1 if b>c else -1
print a if b>c else d
交換兩個(gè)變量
a, b=b, a
連續(xù)賦值
a, b, c=1, 2, 3
串聯(lián)
>>>a=[1,2]
>>>b=[3,4]
>>>a+b
[1,2,3,4]
>>>print str(1) + " a"
1 a
>>>print `1` + " b"
1 b
>>>print 1, " c"
1 c
地板除 (Python 2.2以后)
>>>5//2
2
>>>5.0//2
2.0
乘方
#a**b, a的b次方
>>>2**5
32
級(jí)聯(lián)比較
if a<b<c:
blabla...
if a<b>c:
blabla...
同時(shí)遍歷兩個(gè)列表:
names=['Tom','Jerry']
ages=[23,17]
for name, age in zip(names, ages):
print name, age
建立并初始化列表
#一維
a=[0]*4
#二維, 3行4列
b=[[0]*4 for i in range(3)]
join( )
>>>a=['my', 'life', 'is', 'awesome']
>>>print '!'.join(a)
my!life!is!awesome
獲取字典內(nèi)的元素
#bad implementation:
dix={'Tom':23}
try:
name=dix['Tom']
except KeyError:
name='Default'
#good implementation:
name=dix.get('Tom', 'Default')
截取列表的一部分
>>>a = [1,2,3,4,5,6]
>>>a[:3]
[1,2,3]
>>>a[1:5]
[2,3,4,5]
>>>a[-3:]
[4,5,6]
>>>a[::2]
[1,3,5]
>>>a[1::2]
[2,4,6]
這里的a[x:y:z], x和y分別是下標(biāo)起點(diǎn)看幼,下標(biāo)終點(diǎn)+1批旺,z是間隔值。于是就能理解為啥a[::-1]能得到一個(gè)反轉(zhuǎn)的列表了诵姜。
向列表添加元素
my_list=[1,2,3]
my_list+=4,
#my_list變成了[1,2,3,4]
my_list+=[5]
#my_list變成了[1,2,3,4,5]
參考: