為什么不用參數(shù)?
成都創(chuàng)新互聯(lián)于2013年開(kāi)始,先為高州等服務(wù)建站,高州等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢(xún)服務(wù)。為高州企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問(wèn)題。
pairs.sort(key=lo)
是將整個(gè)pairs迭代后每一次迭代的值都會(huì)傳入lo.
為什么是按照輸出結(jié)果的那種排序方式
lo函數(shù)返回的pair[1],也就是在迭代pairs是傳入的(1,“one”)中的"one"
所以按照字母順序排序的,在第一個(gè)字母相同時(shí),按照第二個(gè)字符排序。
[(4, 'four'), (1, 'one'), (3, 'three'), (2, 'two')]
問(wèn):Python中為什么沒(méi)有swap(a, b)方法?我們?cè)赑ython中如何交換對(duì)象?
Python 不使用這種方式(swap(a, b))。Python以引用方式管理對(duì)象,你可以交換引用,但通常不能交換內(nèi)存中的對(duì)象值。當(dāng)然你也不需要這樣做。
在C++中這種函數(shù)用來(lái)交換“a和b的值”。在Python中,a和b的值不會(huì)發(fā)生交換,但位于當(dāng)前命名空間中的標(biāo)記(如a和b)是可以交換的。而對(duì)象本身是仍然保留。
所以與其調(diào)用一個(gè)swap(a, b),你倒不如使用:a,b = b,a。
通常python函數(shù)不會(huì)混淆它們的命名空間,所以它不能像C++的swap(a, b)那樣進(jìn)行引用操作。
因此,在python中應(yīng)該這樣做:
a = 1
b = 2
def swap(t1, t2):
return t2, t1
a,b = swap(a, b) # After this point, a == 2 and b == 1
But there is not way (other than abusing globals or the module
namespace) to do it like this:
不過(guò)下面這段代碼不可能像我們希望的那樣工作(全局命名空間和局部命名空間是隔離的):
a = 1
b = 2
def swap(t1, t2):
t2, t1 = t1, t2
return
swap(a, b)
# After this point, a == 1 and b == 2. The calling namespace is
# not changed.
在類(lèi)中,你可以構(gòu)造一個(gè)命名空間來(lái)操作可調(diào)用的對(duì)象(類(lèi)實(shí)例方法),事實(shí)上,這意味著也許可以實(shí)現(xiàn)一個(gè)swap()方法。但是它們?nèi)匀恢皇遣僮髅臻g中的對(duì)象引用,而不會(huì)交換對(duì)象本身(或者它們?cè)跈C(jī)器內(nèi)存中的數(shù)據(jù))。以下只是一個(gè)示例,并不表示它們有什么實(shí)用性:
class Pair:
def __init__(self, t1, t2):
self.t1 = t1
self.t2 = t2
def get(self):
return self.t1, self.t2
def swap(self):
self.t1, self.t2 = self.t2, self.t1
a = 1
b = 2
pair = Pair(a, b)
pair.get() # returns 1,2
pair.swap() # changes the namespace of the pair object
pair.get() # returns 2,1
a == 1
b == 2 # The a and b labels did NOT change
lambda 創(chuàng)建一個(gè)匿名函數(shù)。冒號(hào)前面是傳入?yún)?shù),后面是一個(gè)處理傳入?yún)?shù)的單行表達(dá)式。
調(diào)用lambda函數(shù)返回表達(dá)式的結(jié)果。
list的sort 同于內(nèi)建函數(shù)sorted。它有三個(gè)參數(shù)cmp,key,reverse,均有默認(rèn)值。
cmp是一個(gè)比較器,自定義比較器的話傳入兩個(gè)參數(shù)x,y,返回值限制為1(xy), 0(x=y), -1(xy)。默認(rèn)是常規(guī)比較,數(shù)字比較,字符串比較等等。
key是對(duì)序列元素處理(比如問(wèn)題中序列元素仍是序列,就可以再對(duì)序列取索引值),也就是sort的比較器實(shí)際接收到值是key處理后的結(jié)果(問(wèn)題中實(shí)際參與比較的是1,2,3,4)。
reverse默認(rèn)是False,意思是從小到大排序,傳入True,就從大到小排。