摘要:装饰器的应用场景比如插入日志,性能测试,事务处理,缓存等等场景。装饰器完美的遵循了这个开放封闭原则。迭代器迭代器遵循迭代器协议必须拥有方法和方法。直到函数执行结束。调用相关函数用于检查一个对象是否是可调用的。
装饰器 装饰器的含义:
1.装饰器本质上就是一个python函数,他可以让其他函数在不需要做任何代码变动的前提下,增加额外的功能,装饰器的返回值也是一个函数对象。
2.装饰器的应用场景:比如插入日志,性能测试,事务处理,缓存等等场景。
1.现在我有一个需求,我想让你测试这个函数的执行时间,在不改变这个函数代码的情况下:
import time def func1(): time.sleep(0.3) print("in func1") def timer(func): def inner(): start = time.time() func() print(time.time() - start) return inner func1 = timer(func1) func1() 装饰器---简单版
2.但是如果有多个函数,我都想让你测试他们的执行时间,你每次是不是都得func1 = timer(func1)?这样还是有点麻烦,因为这些函数的函数名可能是不相同,有func1,func2,graph,等等,所以更简单的方法,python给你提供了,那就是语法糖。
import time def timer(func): def inner(): start = time.time() func() print(time.time() - start) return inner @timer #==> func1 = timer(func1) def func1(): time.sleep(0.3) print("in func1") func1()
3.刚刚我们讨论的装饰器都是装饰不带参数的函数,现在要装饰一个带参数的函数怎么办呢?
import time def timer(func): def inner(a): start = time.time() func(a) print(time.time() - start) return inner @timer def func1(a): time.sleep(0.3) print(a) func1(1)
4.装饰器通用模板实例:
import time def timer(func): def inner(*args,**kwargs): start = time.time() re = func(*args,**kwargs) print(time.time() - start) return re return inner @timer #==> func1 = timer(func1) def func1(a,b): print("in func1") @timer #==> func2 = timer(func2) def func2(a): print("in func2 and get a:%s"%(a)) return "fun2 over" func1("aaaaaa","bbbbbb") print(func2("aaaaaa"))
5.上面的装饰器已经非常完美了,但是有我们正常情况下查看函数信息的方法在此处都会失效。
import time def timer(func): def inner(*args,**kwargs): """this is inner""" start = time.time() re = func(*args,**kwargs) print(time.time() - start) return re return inner @timer #==> func1 = timer(func1) def func1(a,b): """ this is func1 """ print("in func1") print(func1.__doc__) #查看函数的注释 print(func1.__name__) #查看函数的名字
查看func1的函数注释变成了this is inner
函数的名字变成了inner
解决方法:
from functools import wraps import time def timer(func): @wraps(func) # 加在最内层函数正上方 def inner(*args,**kwargs): """this is inner""" start = time.time() re = func(*args,**kwargs) print(time.time() - start) return re return inner @timer #==> func1 = timer(func1) def func1(a,b): """ this is func1 """ print("in func1") print(func1.__doc__) #查看函数的注释 print(func1.__name__) #查看函数的名字开放封闭原则
1.对扩展是开放的
为什么要对扩展开放呢?
我们说,任何一个程序,不可能在设计之初就已经想好了所有的功能并且未来不做任何更新和修改。所以我们必须允许代码扩展、添加新功能。
2.对修改是封闭的
为什么要对修改封闭呢?
就像我们刚刚提到的,因为我们写的一个函数,很有可能已经交付给其他人使用了,如果这个时候我们对其进行了修改,很有可能影响其他已经在使用该函数的用户。
装饰器完美的遵循了这个开放封闭原则。
1.装饰器的固定格式:
def timer(func): def inner(*args,**kwargs): """执行函数之前要做的""" re = func(*args,**kwargs) """执行函数之后要做的""" return re return inner
2.装饰器的固定格式wraps版:
from functools import wraps def deco(func): @wraps(func) #加在最内层函数正上方 def wrapper(*args,**kwargs): return func(*args,**kwargs) return wrapper带参数的装饰器
假如你有成千上万个函数使用了一个装饰器,现在你想把这些装饰器都取消掉,你要怎么做?
一个一个的取消掉? 没日没夜忙活3天。。。
过两天你领导想通了,再让你加上。。。
def outer(flag): def timer(func): def inner(*args,**kwargs): if flag: print("""执行函数之前要做的""") re = func(*args,**kwargs) if flag: print("""执行函数之后要做的""") return re return inner return timer @outer(False) def func(): print(111) func()多个装饰器装饰一个函数
def wrapper1(func): #f = warpper1(f) 里面的f函数名 外面的f 是inner1 def inner1(): print("wrapper1 ,before func") func() print("wrapper1 ,after func") return inner def wrapper2(func): #f = warpper2(f) 里面的f是inner1 外面的f是inner2 def inner2(): print("wrapper2 ,before func") func() print("wrapper2 ,after func") return inner @wrapper2 @wrapper1 def f(): print("in f") f()
输出为:
wrapper2 ,before func
wrapper1 ,before func
in f
wrapper1 ,after func
wrapper2 ,after func
字符串、列表、元组、字典、集合都可以被for循环,说明他们都是可迭代的。
from collections import Iterable s_str = "1234" l = [1,2,3,4] t = (1, 2, 3,4) d = {1:2,3:4} s_set = {1,2,3,4} print(isinstance(s_str, Iterable)) print(isinstance(l, Iterable)) print(isinstance(t, Iterable)) print(isinstance(d, Iterable)) print(isinstance(s_set,Iterable))可迭代协议
我们现在是从结果分析原因,能被for循环的就是“可迭代的”,但是如果正着想,for怎么知道谁是可迭代的呢?
假如我们自己写了一个数据类型,希望这个数据类型里的东西也可以使用for被一个一个的取出来,那我们就必须满足for的要求。这个要求就叫做“协议”。
可以被迭代要满足的要求就叫做可迭代协议。可迭代协议的定义非常简单,就是内部实现了__iter__方法。
print( "__iter__" in dir(str)) True print(dir(str)) ["__add__", "__class__", "__contains__", "__delattr__", "__dir__", "__doc__", "__eq__", "__format__", "__ge__", "__getattribute__", "__getitem__", "__getnewargs__", "__gt__", "__hash__", "__init__", "__init_subclass__", "__iter__", "__le__", "__len__", "__lt__", "__mod__", "__mul__", "__ne__", "__new__", "__reduce__", "__reduce_ex__", "__repr__", "__rmod__", "__rmul__", "__setattr__", "__sizeof__", "__str__", "__subclasshook__", "capitalize", "casefold", "center", "count", "encode", "endswith", "expandtabs", "find", "format", "format_map", "index", "isalnum", "isalpha", "isdecimal", "isdigit", "isidentifier", "islower", "isnumeric", "isprintable", "isspace", "istitle", "isupper", "join", "ljust", "lower", "lstrip", "maketrans", "partition", "replace", "rfind", "rindex", "rjust", "rpartition", "rsplit", "rstrip", "split", "splitlines", "startswith", "strip", "swapcase", "title", "translate", "upper", "zfill"]
总结一下我们现在所知道的:可以被for循环的都是可迭代的,要想可迭代,内部必须有一个__iter__方法。
接着分析,__iter__方法做了什么事情呢?
可迭代的:内部必须含有一个__iter__方法。
s = "1234" s_obj = s.__iter__() while True: try: print(s_obj.__next__()) except: break
迭代器遵循迭代器协议:必须拥有__iter__方法和__next__方法。
for循环,能遍历一个可迭代对象,他的内部到底进行了什么?
将可迭代对象转化成迭代器。(可迭代对象.__iter__())
内部使用__next__方法,一个一个取值。
加了异常处理功能,取值到底后自动停止。
总结:
迭代器
可迭代对象:
凡是可以用for可以遍历的基本都是可迭代的
str,list,tuple,dict,set,文件句柄,range中
对象中含有__iter__方法的就是可迭代对象,遵循可迭代协议
判断该是否可迭代对象
迭代器含义:
内部含有__iter__且含有__next__方法的对象就是迭代器,遵循迭代器协议
迭代器可以取值,必须通过__next__取值
判断该对象是不是迭代器
迭代器的好处:
减少内存
惰性机制
单向执行,不可逆
生成器 生成器的含义生成器本质就是迭代器,是自己定义的迭代器,单向执行,不可逆
构建方式:
1.函数方式
1.在函数中看到yield,就不是函数了,他就是生成器 2.__next__和yield一一对应 3.--next__和send都可以取值,send会给上一个yield会发送一个值 4.send不能用作第一次取值,最后一个yiled不能取到值
2.列表推导式
1.[变量(加工后的变量)for 变量 in iterable(可迭代对象)] 遍历模式; 2.[变量(加工后的变量)for 变量 in iterable(可迭代对象) if 条件] 筛选模式; 3.特别复杂的无法用列表推导式
3.区别:
1.列表推导式直观可以看出,但是占内存 2.生成器表达式不易看出,但是节省内存
生成器Generator:
1.本质:迭代器(所以自带了__iter__方法和__next__方法,不需要我们去实现)
2.特点:惰性运算,开发者自定义
一个包含yield关键字的函数就是一个生成器函数。yield可以为我们从函数中返回值,但是yield又不同于return,return的执行意味着程序的结束,调用生成器函数不会得到返回的具体的值,而是得到一个可迭代的对象。每一次获取这个可迭代对象的值,就能推动函数的执行,获取新的返回值。直到函数执行结束。
with open("info",encoding="utf-8",mode="r") as f_read: for line in f_read: yield line.strip().split(",")列表推导式和生成器表达式
[变量(加工后的变量)for 变量 in iterable(可迭代对象)
1.列表推导式
l = [i for i in range(10)] print(l) l1 = ["选项%s"%i for i in range(10)] print(l1)
2.把列表解析的[]换成()得到的就是生成器表达式
l = (x for x in range(1,5)) for i in l: print(i)
列表解析与生成器表达式都是一种便利的编程方式,只不过生成器表达式更节省内存
过滤掉长度小于3的字符串列表,并将剩下的转换成大写字母
l = ["abc","ac","accd"] l1 = [i.upper() for i in l if len(i) >=3] print(l1)内置函数 作用域相关
1.locals :函数会以字典的类型返回当前位置的全部局部变量。
2.globals:函数以字典的类型返回全部全局变量
a = 1 b = 2 print(locals()) print(globals()) # 这两个一样,因为是在全局执行的。 ########################## def func(argv): c = 2 print(locals()) print(globals()) func(3) #这两个不一样,locals() {"argv": 3, "c": 2} #globals() {"__doc__": None, "__builtins__":其他相关, "__cached__": None, "__loader__": <_frozen_importlib_external.SourceFileLoader object at 0x0000024409148978>, "__spec__": None, "__file__": "D:/lnh.python/.../内置函数.py", "func": , "__name__": "__main__", "__package__": None}
1.字符串类型代码的执行 eval,exec
eval的含义就是去掉字符串两边的引号,里边该是什么类型就是什么类型
a = ""123"" print(eval(a)) #打印结果为:123
exec
s = """ for i in [1,2,3]: print(i) """ exec(s) 打印结果为: 1 2 3
2.输入输出相关 input,print
def print(self, *args, sep=" ", end=" ", file=None): # known special case of print """ print(value, ..., sep=" ", end=" ", file=sys.stdout, flush=False) file: 默认是输出到屏幕,如果设置为文件句柄,输出到文件 sep: 打印多个值之间的分隔符,默认为空格 end: 每一次打印的结尾,默认为换行符 flush: 立即把内容输出到流文件,不作缓存 """ """ print(111,222,333,sep="*") # 111*222*333 print(111,end="") print(222) #两行的结果 111222 f = open("log","w",encoding="utf-8") print("写入文件",file=f,flush=True)
3.内存相关 hash id
hash:获取一个对象(可哈希对象:int,str,Bool,tuple)的哈希值。
4.文件操作相关
open:函数用于打开一个文件,创建一个 file 对象,相关的方法才可以调用它进行读写。
5.调用相关
callable:函数用于检查一个对象是否是可调用的。如果返回True,object仍然可能调用失败;但如果返回False,调用对象ojbect绝对不会成功。
def add(a,b): return a+b print(callable(add))
6.查看内置属性
dir:函数不带参数时,返回当前范围内的变量、方法和定义的类型列表;带参数时,返回参数的属性、方法列表。如果参数包含方法__dir__(),该方法将被调用。如果参数不包含__dir__(),该方法将最大限度地收集参数信息。
print(dir()) #查看当前模块的属性列表 ["__annotations__", "__builtins__", "__cached__", "__doc__", "__file__", "__loader__", "__name__", "__package__", "__spec__", "s"]获得当前模块的属性列表 print(dir("a")) #查看字符串的属性列表 ["__add__", "__class__", "__contains__", "__delattr__", "__dir__", "__doc__", "__eq__", "__format__", "__ge__", "__getattribute__", "__getitem__", "__getnewargs__", "__gt__", "__hash__", "__init__", "__init_subclass__", "__iter__", "__le__", "__len__", "__lt__", "__mod__", "__mul__", "__ne__", "__new__", "__reduce__", "__reduce_ex__", "__repr__", "__rmod__", "__rmul__", "__setattr__", "__sizeof__", "__str__", "__subclasshook__", "capitalize", "casefold", "center", "count", "encode", "endswith", "expandtabs", "find", "format", "format_map", "index", "isalnum", "isalpha", "isdecimal", "isdigit", "isidentifier", "islower", "isnumeric", "isprintable", "isspace", "istitle", "isupper", "join", "ljust", "lower", "lstrip", "maketrans", "partition", "replace", "rfind", "rindex", "rjust", "rpartition", "rsplit", "rstrip", "split", "splitlines", "startswith", "strip", "swapcase", "title", "translate", "upper", "zfill"]迭代器生成器相关
range:函数可创建一个整数对象,一般用在 for 循环中。
next:内部实际使用了__next__方法,返回迭代器的下一个项目。
# 首先获得Iterator对象: it = iter([1, 2, 3, 4, 5] # 循环: while True: try: # 获得下一个值: x = next(it) print(x) except StopIteration: # 遇到StopIteration就退出循环 break
iter:函数用来生成迭代器(讲一个可迭代对象,生成迭代器)
from collections import Iterable from collections import Iterator l = [1,2,3] print(isinstance(l,Iterable)) # True print(isinstance(l,Iterator)) # False l1 = iter(l) print(isinstance(l1,Iterable)) # True print(isinstance(l1,Iterator))基础数据类型相关
1.数字相关
数据类型:
bool :用于将给定参数转换为布尔类型,如果没有参数,返回 False。
int:函数用于将一个字符串或数字转换为整型。
print(int()) # 0 print(int("12")) # 12 print(int(3.6)) # 3 print(int("0100",base=2)) # 将2进制的 0100 转化成十进制。结果为 4
2.float:函数用于将整数和字符串转换成浮点数。
a = "1.2" print(float(a)) #1.2 b = 1 print(float(b)) #1.0
3.进制转换:
bin:将十进制转换成二进制并返回。
oct:将十进制转化成八进制字符串并返回。
hex:将十进制转化成十六进制字符串并返回。
print(bin(10),type(bin(10))) # 0b1010print(oct(10),type(oct(10))) # 0o12 print(hex(10),type(hex(10))) # 0xa
4.数学运算:
abs:函数返回数字的绝对值。
divmod:计算除数与被除数的结果,返回一个包含商和余数的元组(a // b, a % b)。
round:保留浮点数的小数位数,默认保留整数。
pow:求xy次幂。(三个参数为xy的结果对z取余)
print(abs(-5)) # 5 print(divmod(7,2)) # (3, 1) print(round(7/3,2)) # 2.33 print(round(7/3)) # 2 print(round(3.32567,3)) # 3.326 print(pow(2,3)) # 两个参数为2**3次幂 print(pow(2,3,3)) # 三个参数为2**3次幂,对3取余。
5.sum:对可迭代对象进行求和计算(可设置初始值)。
print(sum([1,2,3])) #6 print(sum((1,2,3),100)) #106
min:返回可迭代对象的最小值(可加key,key为函数名,通过函数的规则,返回最小值)。
print(min([1,2,3])) # 返回此序列最小值 ret = min([1,2,-5,],key=abs) # 按照绝对值的大小,返回此序列最小值 print(ret) dic = {"a":3,"b":2,"c":1} print(min(dic,key=lambda x:dic[x])) # x为dic的key,lambda的返回值(即dic的值进行比较)返回最小的值对应的键
max:返回可迭代对象的最大值(可加key,key为函数名,通过函数的规则,返回最大值)。
print(max([1,2,3])) # 返回此序列最大值 ret = max([1,2,-5,],key=abs) # 按照绝对值的大小,返回此序列最大值 print(ret) dic = {"a":3,"b":2,"c":1} print(max(dic,key=lambda x:dic[x])) # x为dic的key,lambda的返回值(即dic的值进行比较)返回最大的值对应的键和数据结构相关
列表和元祖(2)
list:将一个可迭代对象转化成列表(如果是字典,默认将key作为列表的元素)
tuple:将一个可迭代对象转化成元祖(如果是字典,默认将key作为元祖的元素)
l = list((1,2,3)) print(l) l = list({1,2,3}) print(l) l = list({"k1":1,"k2":2}) print(l) tu = tuple((1,2,3)) print(tu) tu = tuple([1,2,3]) print(tu) tu = tuple({"k1":1,"k2":2}) print(tu)
相关内置函数 :
reversed:将一个序列翻转,并返回此翻转序列的迭代器。
slice:构造一个切片对象,用于列表的切片。
ite = reversed(["a",2,3,"c",4,2]) for i in ite: print(i) li = ["a","b","c","d","e","f","g"] sli_obj = slice(3) print(li[sli_obj]) sli_obj = slice(0,7,2) print(li[sli_obj])
字符串相关
str:将数据转化成字符串。
format:与具体数据相关,用于计算各种小数,精算等。
#字符串可以提供的参数,指定对齐方式,<是左对齐, >是右对齐,^是居中对齐 print(format("test", "<20")) print(format("test", ">20")) print(format("test", "^20")) #整形数值可以提供的参数有 "b" "c" "d" "o" "x" "X" "n" None >>> format(3,"b") #转换成二进制 "11" >>> format(97,"c") #转换unicode成字符 "a" >>> format(11,"d") #转换成10进制 "11" >>> format(11,"o") #转换成8进制 "13" >>> format(11,"x") #转换成16进制 小写字母表示 "b" >>> format(11,"X") #转换成16进制 大写字母表示 "B" >>> format(11,"n") #和d一样 "11" >>> format(11) #默认和d一样 "11" #浮点数可以提供的参数有 "e" "E" "f" "F" "g" "G" "n" "%" None >>> format(314159267,"e") #科学计数法,默认保留6位小数 "3.141593e+08" >>> format(314159267,"0.2e") #科学计数法,指定保留2位小数 "3.14e+08" >>> format(314159267,"0.2E") #科学计数法,指定保留2位小数,采用大写E表示 "3.14E+08" >>> format(314159267,"f") #小数点计数法,默认保留6位小数 "314159267.000000" >>> format(3.14159267000,"f") #小数点计数法,默认保留6位小数 "3.141593" >>> format(3.14159267000,"0.8f") #小数点计数法,指定保留8位小数 "3.14159267" >>> format(3.14159267000,"0.10f") #小数点计数法,指定保留10位小数 "3.1415926700" >>> format(3.14e+1000000,"F") #小数点计数法,无穷大转换成大小字母 "INF" #g的格式化比较特殊,假设p为格式中指定的保留小数位数,先尝试采用科学计数法格式化,得到幂指数exp,如果-4<=exp>> format(0.00003141566,".1g") #p=1,exp=-5 ==》 -4<=exp
>> format(0.00003141566,".2g") #p=1,exp=-5 ==》 -4<=exp
>> format(0.00003141566,".3g") #p=1,exp=-5 ==》 -4<=exp
>> format(0.00003141566,".3G") #p=1,exp=-5 ==》 -4<=exp
>> format(3.1415926777,".1g") #p=1,exp=0 ==》 -4<=exp
>> format(3.1415926777,".2g") #p=1,exp=0 ==》 -4<=exp
>> format(3.1415926777,".3g") #p=1,exp=0 ==》 -4<=exp
>> format(0.00003141566,".1n") #和g相同 "3e-05" >>> format(0.00003141566,".3n") #和g相同 "3.14e-05" >>> format(0.00003141566) #和g相同 "3.141566e-05"
bytes:用于不同编码之间的转化
s = "中国" s1 = s.encode("utf-8") print(s1.decode("utf-8")) #将s1的gbk的bytes类型转成utf-8的bytes类型 s = "中国" s1 = s.encode("gbk") print(s1.decode("gbk").encode("utf-8"))
bytearry:返回一个新字节数组。这个数组里的元素是可变的,并且每个元素的值范围: 0 <= x < 256。
ret = bytearray("alex",encoding="utf-8") print(id(ret)) print(ret) print(ret[0]) ret[0] = 65 print(ret) print(id(ret))
repr:返回一个对象的string形式(原形毕露)。
# %r 原封不动的写出来 # name = "taibai" # print("我叫%r"%name) # repr 原形毕露 print(repr("{"name":"alex"}")) print("{"name":"alex"}")
数据集合
dict:创建一个字典。
set:创建一个集合。
frozenset:返回一个冻结的集合,冻结后集合不能再添加或删除任何元素。
相关内置函数
len:返回一个对象中元素的个数。
sorted:对所有可迭代的对象进行排序操作。
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)]
enumerate:枚举,返回一个枚举对象。
print(enumerate([1,2,3])) for i in enumerate([1,2,3]): print(i) for i in enumerate([1,2,3],100): print(i)
all:可迭代对象中,全都是True才是True
any:可迭代对象中,有一个True 就是True
# all 可迭代对象中,全都是True才是True # any 可迭代对象中,有一个True 就是True # print(all([1,2,True,0])) # print(any([1,"",0]))
zip:函数用于将可迭代的对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的列表。如果各个迭代器的元素个数不一致,则返回列表长度与最短的对象相同。
l1 = [1,2,3,] l2 = ["a","b","c",5] l3 = ("*","**",(1,2,3)) for i in zip(l1,l2,l3): print(i) # (1, "a", "*") (2, "b", "**") (3, "c", (1, 2, 3))
filter:过滤
def func(x):return x%2 == 0 ret = filter(func,[1,2,3,4,5,6,7]) print(ret) for i in ret: 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] # 提供了两个列表,对相同位置的列表数据进行相加 >>> map(lambda x, y: x + y, [1, 3, 5, 7, 9], [2, 4, 6, 8, 10]) [3, 7, 11, 15, 19] #map返回的是一个生成器,,取值要用for循环 for i in map(lambda n:n+"_sb",["oldboy","alex","wusir"]): print(i)匿名函数
匿名函数:为了解决那些功能很简单的需求而设计的一句话函数。
def calc(n): return n**n print(calc(10)) #换成匿名函数 calc = lambda n:n**n print(calc(10))
上面是我们对calc这个匿名函数的分析,下面给出了一个关于匿名函数格式的说明
函数名 = lambda 参数 :返回值
- 参数可以有多个,用逗号隔开 - 匿名函数不管逻辑多复杂,只能写一行,且逻辑执行结束后的内容就是返回值 - 返回值和正常的函数一样可以是任意数据类型
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/41823.html
摘要:变量查找规则在中一个变量的查找顺序是局部环境,闭包,全局,内建闭包引用了自由变量的函数。闭包的作用闭包的最大特点是可以将父函数的变量与内部函数绑定,并返回绑定变量后的函数,此时即便生成闭包的环境父函数已经释放,闭包仍然存在。 导语:本文章记录了本人在学习Python基础之函数篇的重点知识及个人心得,打算入门Python的朋友们可以来一起学习并交流。 本文重点: 1、掌握装饰器的本质、功...
摘要:概括的讲,装饰器的作用就是为已经存在的函数或对象添加额外的功能。在理解这些装饰器之前,最好对函数的闭包和装饰器的接口约定有一定了解。是一个非常简单的装饰器加强包。 Python中的装饰器是你进入Python大门的一道坎,不管你跨不跨过去它都在那里。 为什么需要装饰器 我们假设你的程序实现了say_hello()和say_goodbye()两个函数。 def say_hello(): ...
摘要:在学习的时候,三大名器对没有其他语言编程经验的人来说,应该算是一个小难点,本次博客就博主自己对装饰器迭代器和生成器理解进行解释。 在学习python的时候,三大名器对没有其他语言编程经验的人来说,应该算是一个小难点,本次博客就博主自己对装饰器、迭代器和生成器理解进行解释。 装饰器 什么是装饰器?装饰从字面意思来谁就是对特定的建筑物内按照一定的思路和风格进行美化的一种行为,所谓器就是工具...
摘要:导语本文章汇总了本人在学习基础之绪论篇数据结构篇函数篇面向对象篇控制流程篇和元编程篇学习笔记的链接,打算入门的朋友们可以按需查看并交流。 导语:本文章汇总了本人在学习Python基础之绪论篇、数据结构篇、函数篇、面向对象篇、控制流程篇和元编程篇学习笔记的链接,打算入门Python的朋友们可以按需查看并交流。 第一部分:绪论篇 1、Python数据模型 第二部分:数据结构篇 2、序列构成...
阅读 3828·2021-10-08 10:12
阅读 4324·2021-09-02 15:40
阅读 933·2021-09-01 11:09
阅读 1604·2021-08-31 09:38
阅读 2542·2019-08-30 13:54
阅读 2248·2019-08-30 12:54
阅读 1242·2019-08-30 11:18
阅读 1398·2019-08-29 14:06