python7:装饰器
目录
- 1.调用外部程序
- os.system-阻塞式调用
- subprocess-python中的模块
- 2.装饰器前戏
- 作用域
- (1)全局和局部-就近原则
- (2)嵌套作用域
- (3)内置作用域、变量
- 高阶函数:函数是最高级的对象
- (1)函数名可以被赋值给其他对象
- (2)函数名当作参数传递
- (3)函数名可以作为返回值
- 闭包
- 3.装饰器高阶
- 测试任务
- 装饰器概念
1.调用外部程序
os.system-阻塞式调用
import os #打开操作系统,可以输入命令 os.system("ipconfig") retCode=os.system("mspaint") print("retCode",retCode) print("after")画板打开并关闭后,才执行下一步打印操作
subprocess-python中的模块
subprocess.check_output:以字节形式返回,不能直接打印到控制台
subprocess.Popen:非阻塞式的,可以直接打印到控制台
import subprocess #执行命令,将结果以字节形式返回,bytes output_bytes=subprocess.check_output("ipconfig") print(output_bytes.decode("gbk")) print("=======after=========")#解码转为人能看懂的语言,mac写utf-8,windows写gbk subprocess.Popen("ipconfig") print("=========after================")2.装饰器前戏
作用域
#解决Non-utf-8问题,在python代码最前面放这几行代码
Python file uses the following encoding: utf-8
(1)全局和局部-就近原则
先在自己这一层找
当局部变量和全局变量重名时:
- 在局部作用域使用该变量,则使用局部变量
- 在全局使用时,使用的是全局。
# This Python file uses the following encoding: utf-8 b = 99#全局变量 def foo(): a=100#局部变量 print(a) print(b)#局部作用域使用全局变量,可以 foo() # print(a)#在全局使用局部变量,报错 print(b)# 全局作用域使用全局变量,可以(2)嵌套作用域
# This Python file uses the following encoding: utf-8 b = 99#全局变量 def foo(): a=100#局部变量 print(a) print(b)#局部作用域使用全局变量,可以 def bar(): c=21#嵌套局部变量 print("嵌套==",a,b,c)#嵌套作用域引用局部变量和全局变量 bar() // print(c)#局部引用内置嵌套局部变量,报错 foo() # print(a)#在全局使用局部变量,报错 print(b)# 全局作用域使用全局变量,可以(3)内置作用域、变量
系统内固定模块里预先定义好的变量:
name
os模块里的变量
高阶函数:函数是最高级的对象
(1)函数名可以被赋值给其他对象
def foo(): print("我是一个函数对象") a=foo#将函数对象赋给变量,a就具有了函数foo的特征 print(a) b=foo()#调用函数,并将函数foo的返回值赋给变量b,b就等于foo的返回值 print(b)(2)函数名当作参数传递
def foo1(func): func() def bar(): print("123") foo1(bar)(3)函数名可以作为返回值
#函数名可以作为返回值 def foo(): def bar(): print("过年啦") return bar a=foo() a()闭包
在一个内部函数里边,对在外部作用域(但不是全局作用域)的变量进行引用,那么这个内部函数就被认为是闭包
#闭包 def outer(): x=10 def inner(): print(x) return inner a=outer() a()3.装饰器高阶
测试任务
装饰器概念
为已经存在的对象添加额外的功能
import time #原本逻辑 def foo(): print("执行了一些测试逻辑") time.sleep(1) #新增计时逻辑 def show_time(func): def inner(): begin_time=time.time() func() end_time=time.time() print("用例执行时间==",end_time-begin_time) return inner foo=show_time(foo) foo()foo被装饰函数,show_time是装饰器(装饰函数),python提供了语法糖,在被装饰函数上@装饰器,这样就不用赋值了每次
import time #新增计时逻辑 def show_time(func): def inner(): begin_time=time.time() func() end_time=time.time() print("用例执行时间==",end_time-begin_time) return inner #原本逻辑 @show_time def foo(): print("执行了一些测试逻辑") time.sleep(1) # 省去了赋值的步骤,在外部看来相当于直接调用原函数 foo()
免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!












