• Python__装饰器练习题


    一:编写函数,(函数执行的时间是随机的)

     1 import time
     2 def timmer(func):
     3     def wrapper(*args,**kwargs):
     4         start= time.time()
     5         func(*args,**kwargs)
     6         stop = time.time()
     7         print('执行时间是%s'%(stop-start))
     8      return wrapper
     9 @timmer
    10 def exe():
    11     print('装饰器练习题!')
    12 exe()
    13 
    14 View Code

    二:编写装饰器,为函数加上统计时间的功能

     1 import time
     2 def timmer(func):
     3     def wrapper(*args,**kwargs):
     4         start= time.time()
     5         func(*args,**kwargs)
     6         stop = time.time()
     7         print('执行时间是%s'%(stop-start))
     8      return wrapper
     9 @timmer
    10 def exe():
    11     print('你愁啥!')
    12 exe()
    13 
    14 View Code

    三:编写装饰器,为函数加上认证的功能

     1 def auth(func):
     2     def wrapper(*args,**kwargs):
     3         name = input('请输入你的名字>>: ').strip()
     4         password = input('请输入你的密码>>: ').strip()
     5         if name == 'egon' and password == '123':
     6             func(*args,**kwargs)
     7     return wrapper
     8 @auth
     9 def my_log(name):
    10     print('%s欢迎登陆'%(name))
    11 my_log('egon')
    12 
    13 View Code

    四:编写装饰器,为多个函数加上认证的功能(用户的账号密码来源于文件),要求登录成功一次,后续的函数都无需再输入用户名和密码

    注意:从文件中读出字符串形式的字典,可以用eval(‘{“name”:”egon”,”password”:”123”}’)转成字典格式

     1 current_user = {'name':None}
     2 def auth(func):
     3     def wrapper(*args,**kwargs):
     4         if  current_user['name']:
     5             func(*args, **kwargs)
     6         else:
     7             name = input('请输入你的用户名>>: ').strip()
     8             password = input('请输入你的密码>>: ').strip()
     9             with open('登录文件.txt','r',encoding = 'utf-8') as f:
    10                 line = f.readline()
    11             my_dic = eval(line)
    12             if name == my_dic['name'] and password == my_dic['password']:
    13                 func(*args,**kwargs)
    14                 current_user['name'] = name
    15             else:
    16                 print('your input not exists')
    17      return wrapper
    18 @auth
    19 def my_log():
    20     print('this is my_log')
    21 @auth
    22 def my_name():
    23     print('欢迎登陆')
    24 my_log()
    25 my_name()
    26 
    27 View Code

    五:编写装饰器,为多个函数加上认证功能,要求登录成功一次,在超时时间内无需重复登录,超过了超时时间,则必须重新登录

     1 import time,random
     2 user={'user':None,'login_time':None,'timeout':0.000003,}
     3 def timmer(func):
     4     def wrapper(*args,**kwargs):
     5         s1=time.time()
     6         res=func(*args,**kwargs)
     7         s2=time.time()
     8         print('%s' %(s2-s1))
     9         return res
    10     return wrapper
    11 def auth(func):
    12     def wrapper(*args,**kwargs):
    13         if user['user']:
    14             timeout=time.time()-user['login_time']
    15             if timeout < user['timeout']:
    16                 return func(*args,**kwargs)
    17         name=input('name>>: ').strip()
    18         password=input('password>>: ').strip()
    19         if name == 'egon' and password == '123':
    20             user['user']=name
    21             user['login_time']=time.time()
    22             res=func(*args,**kwargs)
    23             return res
    24     return wrapper
    25 @auth
    26 def index():
    27     time.sleep(random.randrange(3))
    28     print('welcome to index')
    29 @auth
    30 def home(name):
    31     time.sleep(random.randrange(3))
    32     print('welcome %s to home ' %name)
    33 
    34 index()
    35 home('egon')
    36 
    37 View Code

    六:编写下载网页内容的函数,要求功能是:用户传入一个url,函数返回下载页面的结果

    1 import requests
    2 def my_down(url = 'https://www.baidu.com'):
    3     def get():
    4         return requests.get(url).text
    5     return get
    6 baidu_web = my_down()
    7 print(baidu_web())
    8 
    9 View Code

    七:为题目五编写装饰器,实现缓存网页内容的功能:

    具体:实现下载的页面存放于文件中,如果文件内有值(文件大小不为0),就优先从文件中读取网页内容,否则,就去下载,然后存到文件中

    扩展功能:用户可以选择缓存介质/缓存引擎,针对不同的url,缓存到不同的文件中

     1 import requests
     2 import os
     3 cache_file='cache.txt'
     4 def make_cache(func):
     5     def wrapper(*args,**kwargs):
     6         if not os.path.exists(cache_file):
     7             with open(cache_file,'w'):pass
     8 
     9         if os.path.getsize(cache_file):
    10             with open(cache_file,'r',encoding='utf-8') as f:
    11                 res=f.read()
    12         else:
    13             res=func(*args,**kwargs)
    14             with open(cache_file,'w',encoding='utf-8') as f:
    15                 f.write(res)
    16         return res
    17     return wrapper
    18 
    19 @make_cache
    20 def get(url):
    21     return requests.get(url).text
    22 
    23 View Code

    八:还记得我们用函数对象的概念,制作一个函数字典的操作吗,来来来,我们有更高大上的做法,在文件开头声明一个空字典,然后在每个函数前加上装饰器,完成自动添加到字典的操作

     1 route_dic={}
     2 
     3 def make_route(name):
     4     def deco(func):
     5         route_dic[name]=func
     6         return deco
     7 @make_route('select')
     8 def func1():
     9     print('select')
    10 
    11 @make_route('insert')
    12 def func2():
    13     print('insert')
    14 
    15 @make_route('update')
    16 def func3():
    17     print('update')
    18 
    19 @make_route('delete')
    20 def func4():
    21     print('delete')
    22 
    23 print(route_dic)
    24 
    25 View Code

    九 编写日志装饰器,实现功能如:一旦函数f1执行,则将消息2017-07-21 11:12:11 f1 run写入到日志文件中,日志文件路径可以指定

    注意:时间格式的获取

    import time

    time.strftime(‘%Y-%m-%d %X’)

     1 import time,os
     2 def auth(logfile):
     3     def deco(func):
     4         if not os.path.exists(logfile):
     5             with open(logfile,'w',encoding = 'utf-8') as f:
     6                 pass
     7         def wrapper(*args,**kwargs):
     8             res = func(*args,**kwargs)
     9             with open(logfile,'a',encoding = 'utf-8') as f:
    10                 f.write('%s %s run'%(time.strftime('%Y-%m-%d %X'),func.__name__))
    11         return wrapper
    12     return deco
    13 @auth('suhao.txt')
    14 def index():
    15     print('this is my index')
    16 index()
    17 
    18 View Code
  • 相关阅读:
    VC CUtilityLZW 效率还行的LZW压缩算法,随机数加密
    VC CQHashNTBuffer 牛逼的Hash表 UINT32
    VC CHashBuffer 牛逼的hash表算法,字符串查找块了100倍
    关闭Fedora防火墙
    gnome 屏幕截图
    zynq -- arm-xilinx-eabi-路径
    Fedora 14安装出现的错误
    fedora19安装后,需要安装的一些必备的软件包
    zynq -- cannot find -lxil
    Zynq -- 启动过程
  • 原文地址:https://www.cnblogs.com/lz0504/p/9343209.html
Copyright © 2020-2023  润新知