Python中什么是set
dict的作用是建立一組key和一組value的映射關(guān)系,dict的key是不能重復(fù)的。
有的時(shí)候,我們只想要dict的key,不關(guān)心key對(duì)應(yīng)的value,目的就是保證這個(gè)集合的元素不會(huì)重讀,這時(shí),set就派上用場(chǎng)了。
set持有一系列元素,這一點(diǎn)和list很像,但是set的元素沒(méi)有重復(fù),而且是無(wú)序的,這點(diǎn)和dict的key很像:
s = set(['A', 'B', 'C'])
可以查看 set 的內(nèi)容:
print s
set(['A', 'C', 'B'])
請(qǐng)注意,上述打印的形式類似list,但它不是list,仔細(xì)看還可以發(fā)現(xiàn),打印的順序和原始list的順序可能是不同的,因?yàn)閟et內(nèi)部存儲(chǔ)的元素是無(wú)序的。
當(dāng)使用len()方法,獲取set的大小時(shí),set會(huì)自動(dòng)去掉重復(fù)的元素。
Python之 訪問(wèn)set
訪問(wèn)set中的某個(gè)元素實(shí)際上就是判斷一個(gè)元素是否在set中。
我們可以用in 操作符判斷:
s = set(['Adam', 'Lisa', 'Bart', 'Paul'])
'Bart' in s
True
在set中,大小寫(xiě)很重要,表示兩個(gè)不同的元素。
Python之 set的特點(diǎn)
set的內(nèi)部結(jié)構(gòu)和dict很像,唯一區(qū)別是不存儲(chǔ)value,因此,判斷一個(gè)元素是否在set中速度很快。
set存儲(chǔ)的元素和dict的key類似,必須是不變對(duì)象,因此,任何可變對(duì)象是不能放入set中的。
最后,set存儲(chǔ)的元素也是沒(méi)有順序的。
假設(shè)我們讓用戶輸入星期一至星期日的某天,如何判斷用戶的輸入是否是一個(gè)有效的星期呢?
可以用 if 語(yǔ)句判斷,但這樣做非常繁瑣:
x = '???' # 用戶輸入的字符串
if x!= 'MON' and x!= 'TUE' and x!= 'WED' ... and x!= 'SUN':
print 'input error'
else:
print 'input ok'注意:if 語(yǔ)句中的...表示沒(méi)有列出的其它星期名稱,測(cè)試時(shí),請(qǐng)輸入完整。
如果事先創(chuàng)建好一個(gè)set,包含'MON' ~ 'SUN':
weekdays = set(['MON', 'TUE', 'WED', 'THU', 'FRI', 'SAT', 'SUN'])
再判斷輸入是否有效,只需要判斷該字符串是否在set中:
x = '???' # 用戶輸入的字符串
if x in weekdays:
print 'input ok'
else:
print 'input error'
這樣一來(lái),代碼就簡(jiǎn)單多了。
Python之 遍歷set
由于set也是一個(gè)集合,所以便利set和便利list類似,都可以通過(guò)for循環(huán)實(shí)現(xiàn)。
直接使用 for 循環(huán)可以遍歷 set 的元素:s = set(['Adam', 'Lisa', 'Bart'])
for name in s:
... print name
...
Lisa
Adam
Bart
注意:觀察for循環(huán)在遍歷set時(shí),元素的順序和list的順序很可能是不同的,而且不同的機(jī)器上運(yùn)行的結(jié)果也可能不同。
Python之 更新set
由于set存儲(chǔ)的是一組不重復(fù)的無(wú)序元素,因此,更新set主要做兩件事:
一、把新的元素添加到set中;
二、把已有元素從set中刪除。
添加元素時(shí),用set的add()方法s = set([1, 2, 3])
s.add(4)
print s
set([1, 2, 3, 4])
如果添加的元素已經(jīng)存在于set中,add()不會(huì)報(bào)錯(cuò),但是不會(huì)加進(jìn)去了。
s = set([1, 2, 3])
s.add(3)
print s
set([1, 2, 3])
刪除set中的元素時(shí),用set的remove()方法:
s = set([1, 2, 3, 4])
s.remove(4)
print s
set([1, 2, 3])
如果刪除的元素不存在于set中,remove()會(huì)報(bào)錯(cuò)。
所以用add()可以直接添加,而remove()前需要判斷。
Python之什么是函數(shù)
函數(shù)就是最基本的一種代碼抽象的方式。
Python之調(diào)用函數(shù)
調(diào)用 abs 函數(shù):
abs(100)
100
abs(-20)
20
abs(12.34)
12.34
而比較函數(shù) cmp(x, y) 就需要兩個(gè)參數(shù),如果 x<y,返回 -1,如果 x==y,返回 0,如果 x>y,返回 1:
cmp(1, 2)
-1
cmp(2, 1)
1
cmp(3, 3)
0
Python內(nèi)置的常用函數(shù)還包括數(shù)據(jù)類型轉(zhuǎn)換函數(shù),比如 int()函數(shù)可以把其他數(shù)據(jù)類型轉(zhuǎn)換為整數(shù):
int('123')
123
int(12.34)
12
str()函數(shù)把其他類型轉(zhuǎn)換成 str:
str(123)
'123'
str(1.23)
'1.23'
Python之編寫(xiě)函數(shù)
在Python中,定義一個(gè)函數(shù)要使用 def語(yǔ)句,依次寫(xiě)出函數(shù)名、括號(hào)、括號(hào)中的參數(shù)和冒號(hào):,然后,在縮進(jìn)塊中編寫(xiě)函數(shù)體,函數(shù)的返回值用 return 語(yǔ)句返回。
我們以自定義一個(gè)求絕對(duì)值的 my_abs 函數(shù)為例:
def my_abs(x):
if x >= 0:
return x
else:
return -x
注意:函數(shù)體內(nèi)部的語(yǔ)句在執(zhí)行時(shí),一旦執(zhí)行到return時(shí),函數(shù)就執(zhí)行完畢,并將結(jié)果返回。因此,函數(shù)內(nèi)部通過(guò)內(nèi)部條件判斷和循環(huán)可以實(shí)現(xiàn)非常復(fù)雜的邏輯。
如果沒(méi)有return語(yǔ)句,函數(shù)執(zhí)行完畢后會(huì)返回結(jié)果,只是結(jié)果為None。
return None可以簡(jiǎn)寫(xiě)為 return
Python函數(shù)之返回多值
比如在游戲中經(jīng)常需要從一個(gè)點(diǎn)移動(dòng)到另一個(gè)點(diǎn),給出坐標(biāo)、位移和角度,就可以計(jì)算出新的坐標(biāo):
math包提供了sin()和 cos()函數(shù),我們先用import引用它:
import math
def move(x, y, step, angle):
nx = x + step * math.cos(angle)
ny = y - step * math.sin(angle)
return nx, ny
這樣我們就可以同時(shí)獲得返回值:
x, y = move(100, 100, 60, math.pi / 6)
print x, y
151.961524227 70.0
但其實(shí)這只是一種假象,Python函數(shù)返回的仍然是單一值:
r = move(100, 100, 60, math.pi / 6)
print r
s = set([1, 2, 3])
>>> s.add(3)
>>> print s
set([1, 2, 3])
刪除set中的元素時(shí),用set的remove()方法:
>>> s = set([1, 2, 3, 4])
>>> s.remove(4)
>>> print s
set([1, 2, 3])
如果刪除的元素不存在于set中,remove()會(huì)報(bào)錯(cuò)。
所以用add()可以直接添加,而remove()前需要判斷。
#Python之什么是函數(shù)
>函數(shù)就是最基本的一種代碼抽象的方式。
Python之調(diào)用函數(shù)
調(diào)用 abs 函數(shù):
>>> abs(100)
100
>>> abs(-20)
20
>>> abs(12.34)
12.34
而比較函數(shù) cmp(x, y) 就需要兩個(gè)參數(shù),如果 x<y,返回 -1,如果 x==y,返回 0,如果 x>y,返回 1:
>>> cmp(1, 2)
-1
>>> cmp(2, 1)
1
>>> cmp(3, 3)
0
Python內(nèi)置的常用函數(shù)還包括數(shù)據(jù)類型轉(zhuǎn)換函數(shù),比如 int()函數(shù)可以把其他數(shù)據(jù)類型轉(zhuǎn)換為整數(shù):
>>> int('123')
123
>>> int(12.34)
12
str()函數(shù)把其他類型轉(zhuǎn)換成 str:
>>> str(123)
'123'
>>> str(1.23)
'1.23'
Python之編寫(xiě)函數(shù)
>在Python中,定義一個(gè)函數(shù)要使用 def語(yǔ)句,依次寫(xiě)出函數(shù)名、括號(hào)、括號(hào)中的參數(shù)和冒號(hào):,然后,在縮進(jìn)塊中編寫(xiě)函數(shù)體,函數(shù)的返回值用 return 語(yǔ)句返回。
我們以自定義一個(gè)求絕對(duì)值的 my_abs 函數(shù)為例:
def my_abs(x):
if x >= 0:
return x
else:
return -x
注意:函數(shù)體內(nèi)部的語(yǔ)句在執(zhí)行時(shí),一旦執(zhí)行到return時(shí),函數(shù)就執(zhí)行完畢,并將結(jié)果返回。因此,函數(shù)內(nèi)部通過(guò)內(nèi)部條件判斷和循環(huán)可以實(shí)現(xiàn)非常復(fù)雜的邏輯。
如果沒(méi)有return語(yǔ)句,函數(shù)執(zhí)行完畢后會(huì)返回結(jié)果,只是結(jié)果為None。
return None可以簡(jiǎn)寫(xiě)為 return
Python函數(shù)之返回多值
比如在游戲中經(jīng)常需要從一個(gè)點(diǎn)移動(dòng)到另一個(gè)點(diǎn),給出坐標(biāo)、位移和角度,就可以計(jì)算出新的坐標(biāo):
# math包提供了sin()和 cos()函數(shù),我們先用import引用它:
import math
def move(x, y, step, angle):
nx = x + step * math.cos(angle)
ny = y - step * math.sin(angle)
return nx, ny
這樣我們就可以同時(shí)獲得返回值:
>>> x, y = move(100, 100, 60, math.pi / 6)
>>> print x, y
151.961524227 70.0
但其實(shí)這只是一種假象,Python函數(shù)返回的仍然是單一值:
>>> r = move(100, 100, 60, math.pi / 6)
>>> print r
(151.96152422706632, 70.0)
用print打印返回結(jié)果,原來(lái)返回值是一個(gè)tuple!
在語(yǔ)法上,返回一個(gè)tuple可以省略括號(hào),而多個(gè)變量可以同時(shí)接受一個(gè)tuple,按位置付給對(duì)應(yīng)的值,所以,朋友Python的函數(shù)返回多值其實(shí)就是返回一個(gè)tuple,但寫(xiě)起來(lái)更方便。
Python之遞歸函數(shù)
在函數(shù)內(nèi)部,可以調(diào)用其他函數(shù)。如果一個(gè)函數(shù)在內(nèi)部調(diào)用自身本身,這個(gè)函數(shù)就是遞歸函數(shù)。
遞歸函數(shù)的優(yōu)點(diǎn)是定義簡(jiǎn)單,邏輯清晰。理論上,所有的遞歸函數(shù)都可以寫(xiě)成循環(huán)的方式,但循環(huán)的邏輯不如遞歸清晰。
使用遞歸函數(shù),需要放置棧溢出。在計(jì)算機(jī)中,函數(shù)調(diào)用時(shí)通過(guò)棧(stack)這種數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)的,每當(dāng)進(jìn)入一個(gè)函數(shù)調(diào)用,棧就會(huì)加一層棧幀,每當(dāng)函數(shù)返回,棧就會(huì)減一層棧幀。由于棧的大小不是無(wú)限的,所以,地柜調(diào)用的次數(shù)過(guò)多,就會(huì)導(dǎo)致棧溢出。
Python之定義默認(rèn)參數(shù)
定義函數(shù)的時(shí)候,還可以有默認(rèn)參數(shù)。
函數(shù)的默認(rèn)參數(shù)的作用是簡(jiǎn)化調(diào)用,你只需要把必須的參數(shù)傳進(jìn)去。但是在需要的時(shí)候,又可以傳入額外的參數(shù)來(lái)覆蓋默認(rèn)參數(shù)值。
由于函數(shù)的參數(shù)按從左到右的順序匹配,所以默認(rèn)參數(shù)只能定義字必需參數(shù)的后面:
// OK:
def fn1(a, b=1, c=2):
pass
// Error:
def fn2(a=1, b):
pass
Python之定義可變參數(shù)
如果想讓一個(gè)函數(shù)能接受任意個(gè)參數(shù),我們可以定義一個(gè)可變參數(shù):
def fn(*args):
print args
可變參數(shù)的名字前面有個(gè) * 號(hào),我們可以傳入0個(gè)、1個(gè)或多個(gè)參數(shù)給可變參數(shù):fn()
()
fn('a')
('a',)
fn('a', 'b')
('a', 'b')
fn('a', 'b', 'c')
('a', 'b', 'c')
對(duì)于可變參數(shù),Python解釋器會(huì)把傳入的一組參數(shù)組裝成一個(gè)tuple傳遞給可變參數(shù),因此,在函數(shù)內(nèi)部,直接把變量args看成一個(gè)tuple就好了。