week5_notebooke1
大纲:
01 装饰器进阶
02 函数的有效信息
03 可迭代对象、迭代器
04 生成器 列表生成式 生成器表达式
05 内置函数
06 二分查找
01 装饰器进阶
#多个装饰器装饰同一个函数:
## 装饰顺序从近到远
- 先decorate2装饰func,此时decorate2中的f为func函数,返回inner2
- 然后decorate1装饰func,但是此时的func等于inner2,返回inner1
- 最后func等于inner1
## 执行顺序由远到近
- 按照执行顺序,先执行inner1
- 打印inner1 before
- 执行inner2,打印inner2 before
- 执行func,打印execute
- 执行inner2 after
- 执行inner1 after
## 前期可以在f()后加注释,以方便理清装饰顺序,然后按照函数嵌套的执行顺序,判断执行顺序
- 示例一:
def func1(f): # f = wraper2
def wraper1():
print('before wrapper1')
f() # f = wraper2
print('after wrapper1')
return wraper1
def func2(f): # f = wraper3
def wraper2():
print('before wrapper2')
f() # wraper3
print('after wrapper2')
return wraper2
def func3(f): # f = index()
def wraper3():
print('before wrapper3')
f() # index()
print('after wrapper3')
return wraper3
# before wrapper1
# before wrapper2
# before wrapper3
# in anthony
# after wrapper3
# after wrapper2
# after wrapper1
@func1 # func1 = func1(index)
@func2 # func2 = func2(index)
@func3 # func3 = func3(index)
def index():
print('in anthony')
index()
#带参数的装饰器:
示例一:
def timeout(flag):
def func1(f):
def wraper1(*args,**kwargs):
if flag:
f(*args,**kwargs)
print('in anthony')
else:
f(*args, **kwargs)
print('out anthony')
return wraper1
return func1
flag =False
@timeout(flag)
def index():
print('登录中...')
index()
02 函数的有效信息
- 函数注释:
__doc__ #获取函数有效信息
__name__ #得到参数名
from functools import wraps
wraps(f)
- 开放封闭原则:
- 对扩展开放
- 对修改原内容封闭
03 可迭代对象、迭代器
可迭代对象:str,list,tuple,dict,set,range,文件句柄
- 该对象中含有__iter__方法的就是可迭代对象,遵循可迭代协议。
判断是否是可迭代对象:
-- '__iter__' in dir(对象)
-- from collections import Iterable
print(isinstance('abc',Iterable))
迭代器:
含义:内部含有__iter__且含有__next__方法的对象就是迭代器,遵循迭代器协议。
判断是否是迭代器:
-- from collections import Iterator
print(isinstance('abc',Iterator))
-- '__iter__' in dir(对象)
好处:
- 节省内存
- 惰性机制
- 单向执行,不可逆
04 生成器
- 含义:生成器本质就是迭代器,即自定义的迭代器(自定制的迭代器)
- 构成方式:
- 以函数的方式构建
- 生成器表达式
凡是函数中见到yield,即生成器
示例:
def func1():
print(111)
yield 666
print(222)
yield 'anthony'
g_obj = func1() #生成器对象
print(g_obj.__next__())
- 对应规则:__netxt__和yield必须一一对应
- 关于send和next的区别
send和next都是对生成器取值
send会给上一个yield发送一个值
send不能用在第一次取值
最后一个yield,不能得到值
05 列表生成式 生成器表达式
列表推导式格式:简单、一行搞定
# 遍历模式:[变量(加工后的变量) for 变量 in iterable]
示例:l = ['python%s期' % i for i in range(1,11)]
print(l)
# 筛选模式:
示例:l = [i for i in range(1,31) if i%3==0 ]
print(l)
列表推导式优缺点:
缺点:
- 特别复杂数据无法实现,只能用代码实现
- 不能排除错误
生成器表达式:
l_obj = ([i for i in range(1,31) if i%3==0 ])
for i in l_obj:
print(i)
生成器表达式和列表推导式区别:
- 列推直观能看出,但是占内存
- 生成器表达式不易看出,但是节省内存
06 内置函数:python自带内置函数
其他相关:(重点)
- eval:执行字符串类型的代码,并返回最终结果
- exec:执行字符串类型的代码。
- 分割:print(1,2,3,sep='*')
- end:换行
print(111,end='')
print(222)
input:函数接受一个标准输入数据,返回为 string 类型。
print:打印输出。
- print:
with open('练习',encoding='utf-8','w') as f1:
print('wohisshui',file=f1)
- hash:获取一个对象(可哈希对象:int,str,Bool,tuple)的哈希值。
print(hash('anthony'))
print(hash(99))
print(hash(True))
- id:用于获取对象内存地址
- help:查看函数或模块详细信息
- callable:函数用于检查一个对象是否是可调用的。如果返回True,object仍然可能调用失败;但如果返回False,调用对象ojbect绝对不会成功。
- dir:检查对象中的所有方法和属性
- int:print(int()) # 默认为0
print(int(3.6)) # 取值为3,取整
float:函数用于将整数和字符串转换为浮点数
数学相关:
abs:函数返回数字的绝对值。
divmod:计算除数与被除数的结果,返回一个包含商和余数的元组(a // b, a % b)。
round:保留浮点数的小数位数,默认保留整数。
pow:求xy次幂。(三个参数为xy的结果对z取余)
相关内置函数:
reversed:将一个序列翻转,并返回此翻转序列的迭代器。
slice:构造一个切片对象,用于列表的切片。
bytes:用于不同编码之间的转化。将Unicode装换位bytes
ord:输入字符找该字符编码的位置
chr:输入位置数字找出其对应的字符
ascii:是ascii码中的返回该值,不是就返回/u...
repr:返回一个对象的string形式(原形毕露)。
# %r 原封不动的写出来
# name = 'taibai'
# print('我叫%r'%name)
# repr 原形毕露
print(repr('{"name":"alex"}'))
print('{"name":"alex"}')
sorted:对所有可迭代的对象进行排序操作。
示例:
def func(x):return x[1]
L = [('a',3),('d',4),('c',1),('e',2)]
print(sorted(L,key=func))
L = [('a', 1), ('c', 3), ('d', 4),('b', 2), ]
sorted(L, key=lambda x:x[1]) # 利用key
[('a', 1), ('b', 2), ('c', 3), ('d', 4)]
students = [('john', 'A', 15), ('jane', 'B', 12), ('dave', 'B', 10)]
sorted(students, key=lambda s: s[2]) # 按年龄排序
[('dave', 'B', 10), ('jane', 'B', 12), ('john', 'A', 15)]
sorted(students, key=lambda s: s[2], reverse=True) # 按降序
[('john', 'A', 15), ('jane', 'B', 12), ('dave', 'B', 10)]
重要:
zip:函数用于将可迭代的对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的列表。如果各个迭代器的元素个数不一致,则返回列表长度与最短的对象相同。
示例:
l1 = [1,2,3,]
l2 = ['a','b','c',5]
l3 = ('*','**',(1,2,3))
for i in zip(l1,l2,l3):
print(i)
map:会根据提供的函数对指定序列做映射。
>>>def square(x) : # 计算平方数
... return x ** 2
...
>>> map(square, [1,2,3,4,5]) # 计算列表各个元素的平方
[1, 4, 9, 16, 25]
>>> map(lambda x: x ** 2, [1, 2, 3, 4, 5]) # 使用 lambda 匿名函数
[1, 4, 9, 16, 25]
07 匿名函数
# 示例:
func1 = lambda x,y:x+y
print(func1())
06 二分查找
week5_notebooke1的更多相关文章
随机推荐
- java网络编程之socket(1)
网络编程是什么 网络编程的本质是两个设备之间的数据交换,当然,在计算机网络中,设备主要指计算机.数据传递本身没有多大的难度,不就是把一个设备中的数据发送给两外一个设备,然后接受另外一个设备反馈的数据. ...
- 第五周课后作业——适用于人工智能的visual studio 的创新分析
个人觉得作业布置的(2)(3)(4)(5)的顺序并不合理,我将以(5)(2)(3)(4)的顺序开展我的分析. 创新的定义是做出一些改变或创造出新的东西,既是过程,也是结果.这是一个很泛的概念,所以去问 ...
- 使用QT的一些小Tipster
1.在使用Qt Creator编程时,难免会用到将float类型转换为QString类型的方法:原文 1.1. 将QString类型转化为float类型,很简单 QString data; ...
- 5 Python+Selenium的元素定位方法(xpath)
[环境] Python3.6+selenium3.0.2+FireFox50+win7 [定位方法] 1.方法:find_element_by_xpath('') 说明:xpath定位方法有相对路径和 ...
- 02--linux操作系统基础学习笔记
linux是一种操作系统. 嵌入式系统是以应用为中心的,以计算机技术为基础并且软硬件可剪裁,专用计算机系统. 内核下载网站 https://www.kernel.org/ https://www.ke ...
- elasticsearch的核心概念
1.elasticsearch的核心概念 (1)Near Realtime(NRT):近实时,两个意思,从写入数据到数据可以被搜索到有一个小延迟(大概1秒):基于es执行搜索和分析可以达到秒级 (2) ...
- Linux搭建Jenkins
1.添加存储库 yum的repo中默认没有Jenkins,需要先将Jenkins存储库添加到yum repos,执行下面的命令: 使用wget -O下载并以不同的文件名保存 [root@besttes ...
- VS2008集成QT的OpenGL开发(实现二维图形的旋转)
主要是利用Qt中的定时器实现了二维图形的旋转功能: #ifndef QGLTEST_H #define QGLTEST_H #include <QGLWidget> #include &l ...
- Project Euler 27 Quadratic primes( 米勒测试 + 推导性质 )
题意: 欧拉发现了这个著名的二次多项式: f(n) = n2 + n + 41 对于连续的整数n从0到39,这个二次多项式生成了40个素数.然而,当n = 40时402 + 40 + 41 = 40( ...
- 数据库-mongodb-索引
1.索引提高查询速度,降低写入速度,权衡常用的查询字段,不必在太多列上建立索引 2.在mongodb中,索引可以按字段升序.降序来创建,便于排序 3.默认是使用btree 来组织索引文件,2.4版以后 ...