python学习 day12 (3月18日)----(装饰器内置函数)
读时间函数:
# import time
# def func():
# start_time = time.time() # 代码运行之前的时间
# print('这是一个func函数')
# time.sleep(3) # 阻塞,睡一下, 1 是睡一秒
# print(time.time() - start_time) # 代码运行后的时间
# func()
嵌套函数 : (判断每个函数执行空间)
# import time
# def func():
# print('这是func函数')
# time.sleep(1)
#
# def func1():
# print('这是func1函数')
# time.sleep(2)
#
# def func2():
# print('这是func2函数')
# time.sleep(3)
#
# def times():
# start_time = time.time() # 代码运行之前的时间
# func2()
# print(time.time() - start_time) # 代码运行后的时间
# times()
改变了原func()函数体, 第一步执行旧函数的同时,赋值给新函数,然后新函数括号执行

# import time
# def func():
# def inner():
# time.sleep(2)
# print('这是inner函数')
# return inner
# inner = func()
# inner()
把上面的两个函数嵌套和返回混合起来使用就组成了装饰器的雏形


# def warpper():
# print('这是新功能!')
# func()
#
# def func():
# print(1)
#
# warpper() # def func():
# print('这是主功能')
#
# def warpper(f):
# print('这是新功能!')
# return f
# func = warpper(func)
# func()
以上,皆为了满足 以下要求(为了便于维护不破坏原来功能,增加新功能)
开放封闭原则:
对扩展开放
对修改封闭
不改变调用方式
装饰器
# 装饰器 接受被装饰的函数内存地址
def warpper1(f): # 这里 有 f=func1 之后执行 func1()主功能
# 闭包 f = func
def inner(*args , **kwargs): #接受被装饰函数的参数
start_time = time.time()
ret = f(*args,**kwargs) #调用被装饰函数 可以返回值
# time.sleep(*args)
print('这是一个新功能')
end_time = time.time()
print('%s函数的运行时间是:%s' % (f.__name__, end_time - start_time))
return ret #被装饰的函数返回值
return inner # func1 = inner 之后执行 inner()新功能
被装饰函数(内含语法糖)

@warpper1 #语法糖 不改变函数调用方式 原函数是什么只能用什么
# func1 = warpper1(func1) # 传出函数内存地址 调用给wrapper1
# func1() # 被装饰
def func1(*args,**kwargs): # 源代码也没变
print(args)
# print(kwargs)
# time.sleep(args)
print('这是主功能')
return '大妈'
r = func1(5)
print(r)

一层往一层进 ,一层往一层出 包起来
(# 执行的时候 从最上层装饰器开始执行 中间执行被装饰的函数 返回的时候是从下往上走)
def login_auot(f): # 接受一个被装饰的函数内存地址 # f == <function func at 0x0000023D5CE31E18>
def inner(a): # 接受一个被装饰的函数的参数 a = 1
start_time = time.time()
print('这是2') # func
f(a) # 调用被装饰的函数 f(1) == func(1)
print('这是2')
return inner
def auto(f): # 接受一个被装饰的函数内存地址 # f == <function func at 0x0000023D5CE31E18>
def inner(a): # 接受一个被装饰的函数的参数 a = 1
start_time = time.time()
print('这是3') # func
f(a) # 调用被装饰的函数 f(1) == func(1)
print('这是3')
return inner
# @warpper # func = warpper(func)
@login_auot # func = login_auto(func)
@auto
def func(a):
print(1) func(1)
使用规范
# @warpper # 使用规范,装饰放在被装饰的函数离它最近正上方
显示被装饰的函数
# from functools import wraps
#
# def warpper(f):
# @wraps(f) #显示被装饰的函数
# def inner(*args,**kwargs):
# # print(f.__name__)
# print(f)
# return inner #
#
# def aa():
# print(1)
# aa = warpper(aa)
# print(aa.__name__) # 显示被装饰的函数名 # 有参装饰器 咱们不讲 自己研究
1
# def warpper(f): # 接受一个被装饰的函数内存地址 # f == <function func at 0x0000023D5CE31E18>
# def inner(a): # 接受一个被装饰的函数的参数 a = 1
# start_time = time.time()
# print('这是warpper') # func
# f(a) # 调用被装饰的函数 f(1) == func(1)
# print('这是warpper')
# return inner # @warpper
# def func():
# print(1)
# func() # def func():
# print(1)
# func = warpper(func)
# func()
第二节
内置函数

# 1.记住怎么用
# print(abs(-98)) # 求绝对值 正的负的 出来后全都是正的 **
# print(all([1,0,3,4])) # all 判断元素中都为真的才是真 *
# print(any([1,False,0])) # any 判断元素中只要有一个为真就是真 *
# print(ascii('你')) # 查看元素对应的内容
# print(bin(10)) # 将10进制转行2进制 **
# print(bool([1])) # 将内容转换成布尔值
# b = bytearray('meet'.encode('utf-8'))
# # 返回一个新的元组,元组可以切片,切片的内容对应的ascii表
# print(b[3])
# print(bytes('你',encoding='utf-8')) *
# print('你'.encode('utf-8'))
# def func():
# pass
#
# print(callable(func)) # 检查这个对象是否可以调用 **
# print(chr(65)) # 输入数字,返回对应的ascii表位上对应的内容 **
# a = compile('input(">>>")','','exec')
# exec(a)
# print(complex(8)) # 复数 *
# print(dict(key=1,name=2))
# print(dir([1,2])) # 查看对象的所有方法 ***
# print(divmod(5,2)) # 返回一个元组,元组的第一个元素是商,第二个元素是余数 **
# print(enumerate) # 枚举
# li = [1,2,3,4,5,6,7]
#
# for i,em in enumerate(li,1): # enumerate不写值默认是0 ****
# # enumerate 第一个参数是可迭代对象,第二参数是计数
# print(i,em)
# s = """9+4+3""" # 将字符串中内容执行
# print(eval(s)) # 上班以后禁止使用
# li = [1,23,4,]
# s = """
# def func():
# print(1)
# func()
# """
# g = exec(s)
# print(g)
# print(li) # 公司非常禁止
# print(float(20))
# i = 3.56
# print(int(i))
# python3 6 / 3 2.0
# python2 6 / 3 2
# 's'.format() # 字符串的方法
# print(format('a','>10')) # 公用函数 右对齐
# print(format('a','<10')) # 公用函数 左对齐
# print(format('a','^10')) # 公用函数 居中
# print(format(3,'b'))
# print(format(3,'08b')) # 00000011 二进制
# print(format(3,'o')) # 八进制
# print(format(3,'x')) # 八进制
# a = 1
# def func():
# pass
# print(globals()) # 查看全局都哪些内容 **
# print(b)
# print(globals().get('b'))
# dic = {[1,2,3]:1}
# print(hash([1,2,3])) #求对象的哈希值 *
# print(help(input)) # 不知道怎么用的时候可以使用help查看一下
# print(hex(33)) # 将10进制转换成16进制 *
# print(id('s')) # 查看数据的内存地址 ***
# print(input(">>>")) # 获取用户输入的内容 *****
# print(int()) # 将数据转换成整型 *****
# print(isinstance([1,2,3],str)) #判断这个数据时什么类型 ***
# iter # 判断是不是可迭代对象 ***
# len() # 获取数据的长度 *****
# list() # 转换成一个列表 ***
# def func():
# a = 1
# print(locals()) # 查看局部空间的内容 ***
#
# func()
# print(max(1,2,3,4,5)) # 求最大值 ***
# print(min(1,2,3,4)) # 求最小值 ***
# print(memoryview(b'a')) # 查看字节的内存地址
# print(next()) # 迭代器中的取下一个值 ***
# print(oct(9)) # 将10进制转换成8进制 **
# open(文件名,对这个文件要操作的模式,编码)
# '你好'.encode('utf-8')
# coding:utf-8
# print(ord('中')) # 输入的是unicode编码的内容 **
# print(chr(20013)) # 输入的是unicode的内容 **
# print(pow(2,3)) #两个参数的时候求幂运算
# print(pow(2,3)) #三个参数的时候先求幂运算在取余
# print('你好','我好',sep=' ',end='')
# print('大家好')
# print('你好',file=open('a','w',encoding='utf-8'))
# print('123') # 是处理后给你显示的 *****
# print(repr('123')) # 显示的是原数据 ***
# print(list(reversed())) # 反转 元组,列表,字符串 ****
# print(round(5.472343212,3)) #四舍五入 ***
# li = [1,2,3,4]
# # s = slice(2) #切片
# print(li[3])
# print(sum({1:4,2:5})) #求和 ***
# print(type('aasas')) # 获取数据类型
# print(vars(str))
# print(locals())
# li = [1,2,3,4]
# ls = [5,6,7,4,5,6]
# lst = ['a','b','c','d','e']
# print(list(zip(li,ls,lst))) #拉链 ****
# __import__('time') # 导入的方式 ---- > 反射
# 重要的:*************************************************
第三节隐匿函数
# 匿名函数: # lambda 关键字 x参数:x是返回值
# 一行函数 用于简单需求
# print((lambda x:x)(5))
# lambda 的返回值只能是一个 # f = lambda x,y:x*y
# print(f.__name__) #<lambda>
# print(f(5,6)) # print(sorted([7,2,3,4],reverse=True)) # li = ['你好啊','我好','大家都挺好'] # def func(li):
# return len(li)
# print(sorted(li,key=func)) # key指定一个排序的规则 # print(sorted(li,key=lambda x:len(x))) # li = [
# {'age':19},
# {'age':52},
# {'age':48},
# {'age':30},
# ] # def func(li):
# return li['age']
# print(sorted(li,key=func)) # print(sorted(li,key=lambda x:x['age'])) # li = [1,2,3,4]
#
# def func(a):
# if a > 2:
# return a
# print(list(filter(func,li))) # def func(li):
# for i in li:
# if i > 2:
# print(i)
#
# func(li) # li = [1,2,3,4]
#
# print(list(filter(lambda x:x>2,li))) # li = [1,2,3,4,5]
#
# def func(i):
# return i+10
# print(list(map(func,li))) #映射 # li = [1,2,3,4,5]
# print(list(map(lambda x:x+10,li))) # from functools import reduce
#
# li = [1,2,3,4,5]
#
# def func(x,y): # x=12345
# return x*10+y # reduce 是做累计算的
# print(reduce(func,li))
内置函数思维导图
https://www.processon.com/view/5aa09fa4e4b02e58dc3cbc84
python学习 day12 (3月18日)----(装饰器内置函数)的更多相关文章
- python 函数 装饰器 内置函数
函数 装饰器 内置函数 一.命名空间和作用域 二.装饰器 1.无参数 2.函数有参数 3.函数动态参数 4.装饰器参数 三.内置函数 salaries={ 'egon':3000, 'alex':10 ...
- python基础之 装饰器,内置函数
1.闭包回顾 在学习装饰器之前,可以先复习一下什么是闭包? 在嵌套函数内部的函数可以使用外部变量(非全局变量)叫做闭包! def wrapper(): money =10 def inner(num) ...
- python基础 (装饰器,内置函数)
https://docs.python.org/zh-cn/3.7/library/functions.html 1.闭包回顾 在学习装饰器之前,可以先复习一下什么是闭包? 在嵌套函数内部的函数可以使 ...
- Python学习日记(二十七) 反射和几个内置函数
isinstance() 判断isinstance(obj,cls)中obj是否是cls类的对象 class Person: def __init__(self,name): self.name = ...
- Python 学习日志9月18日
今天早晨学习了<Head First HTML and CSS>,第10章“div and span”. 看完并且做了练习也算是对div和span扫了个盲,需要在实践练习中加强理解与掌握. ...
- python装饰器内获取函数有用信息方法
装饰器内获取函数有用信息方法 .__doc__用于得到函数注释信息 .__name_用于得到函数名 在函数引用装饰器的时候,函数名会变为装饰器内部执行该函数的名字,所有在直接执行函数名加.__doc_ ...
- Python学习日志9月17日 一周总结
周一,9月11日 这天写的是过去一周的周总结,我从中找出当天的内容. 这天早晨给电脑折腾装机,早晨基本上没有学习,休息了一个早晨. 下午写的上周总结,完事做mooc爬虫课的作业,<Think P ...
- Python 学习日志9月19日
9月19日 周二 今天是普通的一天,昨天也是普通的一天,刚才我差点忘记写日志,突然想起来有个事情没做,回来写. 今天早晨学习<Head First HTML and CSS>第十一章节“布 ...
- python学习 day7 (3月8日)
read()读出来了之后文件里就从之后开始 光标不知道在哪 编码的进阶: 背景: ASCII:英文字母,数字,特殊符号,------------>二进制的对应关系 str: 一个字符 ---- ...
随机推荐
- Linux下查看编辑二进制文件:hexedit神器
1.如果没有hexedit安装hexedit:2.打开终端输入hexedit filename;3.打开即可用键盘输入字符,用方向键移动,ctrl+w保存,ctrl+x退出:4.详细用法 man he ...
- MongoDB修改默认数据库
在某些情况下,我们并不想把mongoDB的数据库放在c盘,这时候有两种方法可以切换数据库目录. 1.命令方式 首先创建数据路目录,例如:E:\data\db.然后运行命令 mongod -dbpath ...
- 191. Number of 1 Bits (Int; Bit)
Write a function that takes an unsigned integer and returns the number of ’1' bits it has (also know ...
- 命令行操作mysql数据库
1.导出整个数据库mysqldump -u 用户名 -p 数据库名 > 导出的文件名 mysqldump -u dbuser -p dbname > dbname.sql 2.导出一个表m ...
- PHP简单工厂模式、工厂方法模式和抽象工厂模式比较
PHP工厂模式概念:工厂模式是一种类,它具有为您创建对象的某些方法.您可以使用工厂类创建对象,而不直接使用 new.这样,如果您想要更改所创建的对象类型,只需更改该工厂即可.使用该工厂的所有代码会自动 ...
- 【nginx】配置详解
nginx作为web server,是最常用的网络服务器.来看下它的配置文件. 实验1:最基础的配置(可访问静态资源) 包括listen,server_name,root,index,access_l ...
- 非线性优化(高翔slam---第六讲 )
1.线性最小二乘问题 2.非线性最小二乘问题 因为它非线性,所以df/dx有时候不好求,那么可以采用迭代法(有极值的话,那么它收敛,一步步逼近): 这样求导问题就变成了递归逼近问题,那么增量△xk如何 ...
- webstorm配置node.js
1.确保电脑已经安装好了node.js
- H5笔记周记
9.4 一.介绍浏览器 1.title 主题,题目 2.url 网址 3.body 网站的内容 4.html 语言,超文本标记语言 二.文件介绍 三.标签的结构 (一些快捷键:Ctrl+s 保存 ...
- Windows Live Writer
一.简介 Windows Live Writer 是一个强大的离线博客编辑工具,通过它可以离线编辑内容丰富的博文,除了自身强大的编辑功能之外,还提供了接口,让其它开发人员通过插件提供工具自身没有提供的 ...