python语言入门 第五天

大纲:

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 二分查找

原文地址:https://www.cnblogs.com/ipyanthony/p/9126378.html