练习题:
一:编写函数,(函数执行的时间是随机的)
import time,sys,os,requests
def my_def():
time.sleep(1)
print('哈哈哈哈')
my_def()
二:编写装饰器,为函数加上统计时间的功能
def wrapper(func):
def timmer(*args,**kwargs):
start=time.time()
func()
stop=time.time()
print('run time is %s'%(stop-start))
return timmer
三:编写装饰器,为函数加上认证的功能
def auth(func):
user=input('please input name>>:').strip()
pwd=input('please input password>>:')
def auth1(auth_type='file',*args,**kwargs):
if auth_type=='file':
if user=='egon'and pwd=='egon123':
print('登陆成功!正在跳转...')
func()
else:
print('输入的用户名或密码错误,请重新输入!')
elif auth_type=='mysql':
print('from mysql')
return auth1
四:编写装饰器,为多个函数加上认证的功能(用户的账号密码来源于文件),要求登录成功一次,后续的函数都无需再输入用户名和密码
注意:从文件中读出字符串形式的字典,可以用eval('{"name":"egon","password":"123"}')转成字典格式
五:编写装饰器,为多个函数加上认证功能,要求登录成功一次,在超时时间内无需重复登录,超过了超时时间,则必须重新登录
六:编写下载网页内容的函数,要求功能是:用户传入一个url,函数返回下载页面的结果
七:为题目五编写装饰器,实现缓存网页内容的功能:
具体:实现下载的页面存放于文件中,如果文件内有值(文件大小不为0),就优先从文件中读取网页内容,否则,就去下载,然后存到文件中
扩展功能:用户可以选择缓存介质/缓存引擎,针对不同的url,缓存到不同的文件中
八:还记得我们用函数对象的概念,制作一个函数字典的操作吗,来来来,我们有更高大上的做法,在文件开头声明一个空字典,然后在每个函数前加上装饰器,完成自动添加到字典的操作
九 编写日志装饰器,实现功能如:一旦函数f1执行,则将消息2017-07-21 11:12:11 f1 run写入到日志文件中,日志文件路径可以指定
注意:时间格式的获取
import time
time.strftime('%Y-%m-%d %X')
作业需求:
模拟实现一个ATM + 购物商城程序
- 额度 15000或自定义
- 实现购物商城,买东西加入 购物车,调用信用卡接口结账
- 可以提现,手续费5%
- 支持多账户登录
- 支持账户间转账
- 记录每月日常消费流水
- 提供还款接口
- ATM记录操作日志
- 提供管理接口,包括添加账户、用户额度,冻结账户等。。。
- 用户认证用装饰器
代码太多 不能传附件,尴尬!!!