一:编写函数,(函数执行的时间是随机的)
import random
def t():
time.sleep(random.randrange(1,3))
print(‘hello’)
二:编写装饰器,为函数加上统计时间的功能
import time
import random
def timebe(func):
def wrapper(*args,**kwargs):
start_time=time.time()
res = func(*args, **kwargs)
end_time=time.time()
print(‘运行时间是:%s’ % (end_time - start_time))
return res
return wrapper
@timebe
def t():
time.sleep(random.randrange(2,3))
print(‘hello’)
三:编写装饰器,为函数加上认证的功能
def ident(func):
def wrapper(*args,**kwargs):
name=input(‘name:’)
pwd=input(‘pwd: ‘)
if name==’zuo’ and pwd==’123’:
print(‘correct’)
return func(*args, **kwargs)
else:
print(‘wrong’)
return wrapper
@ident
def t():
print(‘hello’)
四:编写装饰器,为多个函数加上认证的功能(用户的账号密码来源于文件),要求登录成功一次,后续的函数都无需再输入用户名和密码
注意:从文件中读出字符串形式的字典,可以用eval(‘{“name”:”egon”,”password”:”123”}’)转成字典格式
def iden(func):
def wrapper(*args,**kwargs):
name=input(‘name:’)
pwd=int(input(‘pwd:’))
with open(‘1.txt’,’r’) as f:
a=f.read()
a=eval(a)
if name in a and pwd==a[name]:
print(‘corret’)
return func(*args,**kwargs)
else:
print(‘error’)
return wrapper
@iden
def s(x,y):
print(‘sum=%s’ %(x+y))
@iden
def mi(a,b):
if a>b:
print(b)
else:
print(a)
五:编写下载网页内容的函数,要求功能是:用户传入一个url,函数返回下载页面的结果
from urllib.request import urlopen
def index():
url=’http://cn.bing.com/’
def get():
return urlopen(url).readlines()
return get
biying=index()
print(biying())
六:为题目五编写装饰器,实现缓存网页内容的功能:
具体:实现下载的页面存放于文件中,如果文件内有值(文件大小不为0),就优先从文件中读取网页内容,否则,就去下载,然后存到文件中
七:还记得我们用函数对象的概念,制作一个函数字典的操作吗,来来来,我们有更高大上的做法,在文件开头声明一个空字典,然后在每个函数前加上装饰器,
完成自动添加到字典的操作
原文连接:
1.python之闭包函数 装饰器 练习。