zoukankan      html  css  js  c++  java
  • 第四次作业

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

    import time
    def timmer(func):
        def wrapper(*args,**kwargs):
            start= time.time()
            func(*args,**kwargs)
            stop = time.time()
            print('执行时间是%s'%(stop-start))
        return wrapper
    @timmer
    def exe():
        print('装饰器练习题!')
    exe()
    

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

    import time
    def timmer(func):
    def wrapper(*args,**kwargs):
    start= time.time()
    func(*args,**kwargs)
    stop = time.time()
    print('执行时间是%s'%(stop-start))
    return wrapper
    @timmer
    def exe():
    print('钟意你!')
    exe()

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

    def auth(func):
        def wrapper(*args,**kwargs):
            name = input('请输入你的名字>>: ').strip()
            password = input('请输入你的密码>>: ').strip()
            if name == 'sean' and password == '111':
                func(*args,**kwargs)
        return wrapper
    @auth
    def my_log(name):
        print('%s欢迎登陆'%(name))
    my_log('sean')
    

    四:编写装饰器,为多个函数加上认证的功能(用户的账号密码来源于文件),要求登录成功一次,后续的函数都无需再输入用户名和密码
    注意:从文件中读出字符串形式的字典,可以用eval('{"name":"egon","password":"123"}')转成字典格式

    current_user = {'name':None}
    def auth(func):
        def wrapper(*args,**kwargs):
            if  current_user['name']:
                func(*args, **kwargs)
            else:
                name = input('请输入你的用户名>>: ').strip()
                password = input('请输入你的密码>>: ').strip()
                with open('登录文件.txt','r',encoding = 'utf-8') as f:
                    line = f.readline()
                my_dic = eval(line)
                if name == my_dic['name'] and password == my_dic['password']:
                    func(*args,**kwargs)
                    current_user['name'] = name
                else:
                    print('your input not exists')
        return wrapper
    @auth
    def my_log():
        print('this is my_log')
    @auth
    def my_name():
        print('欢迎登陆')
    my_log()
    my_name()
    

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

    import time,random
    user={'user':None,'login_time':None,'timeout':0.000003,}
    def timmer(func):
        def wrapper(*args,**kwargs):
            s1=time.time()
            res=func(*args,**kwargs)
            s2=time.time()
            print('%s' %(s2-s1))
            return res
        return wrapper
    def auth(func):
        def wrapper(*args,**kwargs):
            if user['user']:
                timeout=time.time()-user['login_time']
                if timeout < user['timeout']:
                    return func(*args,**kwargs)
            name=input('name>>: ').strip()
            password=input('password>>: ').strip()
            if name == 'sean' and password == '11':
                user['user']=name
                user['login_time']=time.time()
                res=func(*args,**kwargs)
                return res
        return wrapper
    @auth
    def index():
        time.sleep(random.randrange(3))
        print('welcome to index')
    @auth
    def home(name):
        time.sleep(random.randrange(3))
        print('welcome %s to home ' %name)
    
    index()
    home('sean')
    

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

    def objt():
        url = input('请输入URL路径:')
        from urllib.request import urlopen
        ret = urlopen(url).read()
        return ret
    
    ret = objt()
    ret = ret.decode('utf-8')
    import os
    with open('aa.html', 'w', encoding='utf-8') as html:
        html.write(ret)
    

    七:为题目六编写装饰器,实现缓存网页内容的功能:
    具体:实现下载的页面存放于文件中,如果文件内有值(文件大小不为0),就优先从文件中读取网页内容,否则,就去下载,然后存到文件中

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

    from urllib.request import urlopen
    import os
    
    def cache(func):
        def inner(*args, **kwargs):
            if os.path.getsize("web_html"):  # 判断文件大小调用OS模块
                with open("web_html", "rb") as f:
                    return f.read()  # 如果文件不为空,则直接返回
            ret = func(*args, **kwargs)
            with open("web_html", "wb") as f:
                f.write(b"***" + ret)
            return ret
            return inner
    
    @cache
    def get_url(url):
        code = urlopen(url).read()
        return code
    

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

    dic = {}
    
    def make(ch):
        def wrap(func):
            def inner():
             dic[ch] = func
            return inner
        return wrap
    @make('select')
    def select():
        print("select!!")
    @make('update')
    def update():
        print("update!!")
    
    select()
    update()
    
    
    print(dic)
    

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

    import time,os
    def auth(logfile):
        def deco(func):
            if not os.path.exists(logfile):
                with open(logfile,'w',encoding = 'utf-8') as f:
                    pass
            def wrapper(*args,**kwargs):
                res = func(*args,**kwargs)
                with open(logfile,'a',encoding = 'utf-8') as f:
                    f.write('%s %s run'%(time.strftime('%Y-%m-%d %X'),func.__name__))
            return wrapper
        return deco
    @auth('suhao.txt')
    def index():
        print('this is my index')
    index()
    

      

  • 相关阅读:
    uniapp跨域
    uniapp图片文件转base64
    懒加载
    修改富文本样式
    搜集到的常用Scheme
    JS浏览器复制
    程序员必须知道的六大ES6新特性
    详解ES6中的 let 和const
    数据库基础
    配置环境变量
  • 原文地址:https://www.cnblogs.com/datatool/p/13448998.html
Copyright © 2011-2022 走看看