*装饰器其实就是利用闭包功能对函数进行增强
*装饰器格式为: @闭包函数名
def show(fun1): def show_in(): fun1() sumdate = 0 for i in range(1,101): if i%2 == 1 : sumdate += i print(sumdate) return show_in @show def odd_sum(): print('1到100的奇数和:') odd_sum()
输出结果:
1到100的奇数和:
2500
def show(fun1): def show_in(): fun1() sumdate = 0 for i in range(1,101): if i%2 == 1 : sumdate += i print(sumdate) return show_in def odd_sum(): print('1到100的奇数和:') odd_sum = show(odd_sum) odd_sum()
案例分析有装饰器的代码,并没有像闭包那样,明显的有odd_sum = show(odd_sum)语句,只是把这句省略了,利用装饰穷程序中会自动调用odd_sum = show(odd_sum)语句
在主函数上方加上@show(@后面接辅助函数名),就表明将主函数作为参数传入show函数fun1中,让show函数和odd_sum函数具有了联系
看看下面这个案例
def show(fun1): print('1到100的奇数和:') def show_in(): fun1() sumdate = 0 for i in range(1,101): if i%2 == 1 : sumdate += i print(sumdate) return show_in @show def odd_sum(): pass odd_sum() print('-------------') odd_sum()
输出结果:
1到100的奇数和:
2500
'-------------'
2500
*案例分析第一次显示了“1到100的奇数和:”,第二次却没有
*第二次只会使用这个已经增强的函数,不会显示过程
*仅仅只会使用这一段
def show_in(): fun1() sumdate = 0 for i in range(1,101): if i%2 == 1 : sumdate += i print(sumdate)