def count():
fs = []
for i in range(1, 4):
def foo(i):
def bar():
return i*i
return bar
fs.append(foo(i))
return fs
f1, f2, f3 = count()
print f1(), f2(), f3()
fs = []
for i in range(1, 4):
def foo(i):
def bar():
return i*i
return bar
fs.append(foo(i))
return fs
f1, f2, f3 = count()
print f1(), f2(), f3()
2020-02-07
sorted = functools.partial(sorted,key=lambda a: a.name.lower())
2020-02-05
第三部分:
@performance('ms')
def factorial(n):
return reduce(lambda x,y: x*y, range(1, n+1))
print factorial.__name__
@performance('ms')
def factorial(n):
return reduce(lambda x,y: x*y, range(1, n+1))
print factorial.__name__
2020-02-05
第二部分:
# 即,當該函數完成后,factorial實際上是__performance函數,
# 只是名字變了
@functools.wraps(f)# 這里復制了factorial的函數名
def __performance(*args, **kw):# 傳入factorial修飾前的參數
return
return __performance
return _performance
# 即,當該函數完成后,factorial實際上是__performance函數,
# 只是名字變了
@functools.wraps(f)# 這里復制了factorial的函數名
def __performance(*args, **kw):# 傳入factorial修飾前的參數
return
return __performance
return _performance
2020-02-05
本節詳解:
第一部分
#coding:utf-8
#上面那一行為了改變編碼方式,不然無法運行
import time, functools
def performance(unit):
# 第一層,調用時,傳入'ms',
# 返回_performance函數
def _performance(f):
# 第二層,調用時,傳入factorial,
# 返回__performance函數,并將其#賦值給factorial
第一部分
#coding:utf-8
#上面那一行為了改變編碼方式,不然無法運行
import time, functools
def performance(unit):
# 第一層,調用時,傳入'ms',
# 返回_performance函數
def _performance(f):
# 第二層,調用時,傳入factorial,
# 返回__performance函數,并將其#賦值給factorial
2020-02-05
這幾節內容并不難,惡心的是每一節的代碼任務很不清晰,加上小白對于模塊的應用兩眼一抹黑,不覺得難才怪。這幾節很不負責任
2020-02-05
這樣就行
def cmp_ignore_case(s1, s2):
if s1.capitalize()==s2.capitalize():
return 0
elif s1.capitalize()>s2.capitalize():
return 1
else:
return -1
print sorted(['bob', 'about', 'Zoo', 'Credit'], cmp_ignore_case)
def cmp_ignore_case(s1, s2):
if s1.capitalize()==s2.capitalize():
return 0
elif s1.capitalize()>s2.capitalize():
return 1
else:
return -1
print sorted(['bob', 'about', 'Zoo', 'Credit'], cmp_ignore_case)
2020-01-31
def func1(x): #用x接收參數一
def func2(f): #用f接受函數main
@functools.wraps(f)
def func3(*args,**kw):
return f() #調用f()把返回值傳遞給func3
return func3 #func3閉包傳遞出去
return func2 #同理
@func1(參數一)
def main(a,b,c,...):
return
main(a,b,c,...)
print main.__name__ #輸出檢驗是否修正
def func2(f): #用f接受函數main
@functools.wraps(f)
def func3(*args,**kw):
return f() #調用f()把返回值傳遞給func3
return func3 #func3閉包傳遞出去
return func2 #同理
@func1(參數一)
def main(a,b,c,...):
return
main(a,b,c,...)
print main.__name__ #輸出檢驗是否修正
2020-01-30
裝飾器基本框架
def func1(fun):
def func2():
return fun()
return func2
@fun1
def main():
return a
main()
裝飾器運行思路
1.運行func1(main)
2.創建了func2 ()
3.創建結束后調用main()
4.調用main的輸出和返回值保存在func2的返回值中 func2目前未被調用
5.這個時候func(main)運行完畢
6.func(main)的返回值是func2
def func1(fun):
def func2():
return fun()
return func2
@fun1
def main():
return a
main()
裝飾器運行思路
1.運行func1(main)
2.創建了func2 ()
3.創建結束后調用main()
4.調用main的輸出和返回值保存在func2的返回值中 func2目前未被調用
5.這個時候func(main)運行完畢
6.func(main)的返回值是func2
2020-01-30
說實話可能會被噴。僅僅說我個人感覺,教程每個章節都說的比較簡潔,漏了不少知識點,需要自己去查,不然完成不了任務,不過任務題目出的真不錯,我感覺其實可以自己看看其他詳細的課程,然后來這完成課程就好了。
2020-01-30
import math
def is_sqr(x):
if int(math.sqrt(x))**2 == x :
return x
print filter(is_sqr, range(1,101))
def is_sqr(x):
if int(math.sqrt(x))**2 == x :
return x
print filter(is_sqr, range(1,101))
2020-01-10