欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

day 11 - 2 装饰器练习

程序员文章站 2022-06-06 20:45:41
1、编写装饰器,为多个函数加上认证的功能(用户的账号密码来源于文件)要求登录成功一次,后续的函数都无需再输入用户名和密码 2、编写装饰器,为多个函数加上记录调用功能,要求每次调用函数都将被调用的函数名称写入文件 进阶练习:1.编写下载网页内容的函数,要求功能是:用户传入一个url,函数返回下载页面的 ......

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

flag = false
def login(func):
    def inner(*args,**kwargs):
        global flag
        if flag:
            ret = func(*args,**kwargs)
            return ret
        else:
            #登录程序
            username = input('请输入用户名:')
            password = input('请输入密码:')
            if username == 'ysg' and password == "275":
                flag = true
                ret = func(*args,**kwargs)
                return ret
            else:
                print("登录失败")
    return inner

@login
def shoplist_add():
    print("向购物车中添加物品")

@login
def shoplist_del():
    print("向购物车中添加物品")


shoplist_add()
shoplist_del()

 

2、编写装饰器,为多个函数加上记录调用功能,要求每次调用函数都将被调用的函数名称写入文件

def log(func):
    def inner(*arge,**kwargs):
        with open('e:/py/log/log.txt','a',encoding='utf-8') as f:
            f.write(func.__name__ + '\n')
        ret = func(*arge,**kwargs)
        print("")
        return ret
    return inner

@log
def shoplist_add():
    print("购买了一件商品")

@log
def shoplist_del():
    print("删除了一件商品")

shoplist_add()
shoplist_del()
shoplist_add()
shoplist_del()
shoplist_add()
shoplist_del()

 

进阶练习:
1.编写下载网页内容的函数,要求功能是:用户传入一个url,函数返回下载页面的结果
2.为题目1编写装饰器,实现缓存网页内容的功能:
具体:实现下载的页面存放于文件中,如果文件内有值(文件大小不为0),就优先文件中读取网页内容,否则,就去下载,然后存到文件中

import os
from urllib.request import urlopen
def cache(func):
    def inner(*arge,**kwargs):
        if os.path.getsize('e:/py/log/url.txt'):
            with open ("e:/py/log/url.txt","rb") as f:
                return f.read()
        ret = func(*arge,**kwargs)
        with open('e:/py/log/url.txt','wb') as f:
            f.write(ret+b"*****")
        return ret
    return inner

@cache
def get(url):
    code = urlopen(url).read()
    return code

ret = get('http://www.baidu.com')
print(ret)

ret = get('http://www.baidu.com')
print(ret)