0.本周知识点预览
- 内置函数
- 装饰器基础
1.内置函数进阶
1.chr()、ord()
print(chr(66))
print(ord("F"))
执行结果如下
B
70
总结:chr()函数是把数字转换成相应ASCII码对应的值,ord()和chr()相反,可以把ASCII码对应的值转换成数字。
2.random()
import random
list = []
for i in range(6):
r = random.randrange(0,6)
if r == 0 or r == 2:
num = random.randrange(0,10)
list.append(str(num))
elif r == 1 or r == 3:
num = random.randrange(65,91)
ret = chr(num)
list.append(ret)
else:
num = random.randrange(97,113)
ret = chr(num)
list.append(ret)print("".join(list))
执行结果如下
aA3cc4
总结:random模块的randrange()方法返回一个随机数,上述代码返回一个6位随机的验证码。
3.compile()、eval()、exec()
1.compile()
eval_code = compile( '1+2', '', 'eval')
ret = eval(eval_code)
print(ret)
执行结果如下
3
总结:compile()方法是把str里的语句编译成代码对象
2.eval()
num = 10
ret = eval('num * 7')
print(ret)
执行结果如下
70
总结:eval()方法是用来执行字符串中的有效的python表达式,注意eval()是有返回值的。
3.exec()
a=1
exec("a=a+10")
print(a)
执行结果如下
11
总结:exec()方法用来执行存储在str中的python代码。
4.dir()、help()
a=[1,2,3]
ret = dir(a)
print(ret)
执行结果如下
['__add__', '__class__', '__contains__', '__delattr__', '__delitem__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__gt__', '__hash__', '__iadd__', '__imul__', '__init__', '__iter__', '__le__', '__len__', '__lt__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__reversed__', '__rmul__', '__setattr__', '__setitem__', '__sizeof__', '__str__', '__subclasshook__', 'append', 'clear', 'copy', 'count', 'extend', 'index', 'insert', 'pop', 'remove', 'reverse', 'sort']
========================================================================================
a=[1,2,3]
ret = help(a)
print(ret)
执行结果如下
Help on list object:
class list(object)
| list() -> new empty list
| list(iterable) -> new list initialized from iterable's items
|
| Methods defined here:
|
| __add__(self, value, /)
| Return self+value.
|
| __contains__(self, key, /)
| Return key in self.
......
总结:dir()、help()方法会打印函数的帮助信息,help会比dir更详细
5.isinstance()
testlist = [1,2,3]
ret1 = isinstance(testlist,list)
ret2 = isinstance(testlist,tuple)
print(ret1,ret2)
执行结果如下
True False
总结:isinstance()方法,会判断第一个参数是否是第二个参数的子类,返回True或者False。
6.filter()、map()
1.filter()
a= [1,3,5,7,8,9]
def f1(num):
return num>5
ret = filter(f1,a)
print(list(ret))
执行结果如下
[7, 8, 9]
总结:filter()方法的第一个参数是一个函数,第二个参数是一个可迭代的对象,它会循环第二个参数,让每个元素循环执行函数,如果函数返回为True,表示元素合法,添加到结果中。
2.map()
c = [1,3,4,5,7,10]
ret = map(lambda num: num + 20,c)
print(list(ret))
执行结果如下
[21, 23, 24, 25, 27, 30]
总结:map()方法的第一个参数是一个函数,第二个参数是一个可迭代的对象,它会循环第二个参数,让每个元素循环执行函数,将函数返回值添加到结果中。
7.zip()
a = ["lk",11,22,33]
b = ["is",7,8]
c = ["god","haha",123]
print(list(zip(a,b,c)))
执行结果如下
[('lk', 'is', 'god'), (11, 7, 'haha'), (22, 8, 123)]
总结:zip()函数的参数是N个可迭代的对象,返回值是迭代对象聚合后的元组,用list()可以使其转化为列表。列表长度为最短参数的长度。
2.装饰器
1.初识
1.被装饰函数无返回值
def outer(func):
def inner():
print("logging....")
func()
return inner
@outer
def b1():
print("b1.......")
def b2():
print("b2.......")
def b3():
print("b3.......")
b1()
执行结果如下:
logging....
b1.......
代码剖析:装饰器的用法:@ + 函数名;装饰器的功能:
1.自动执行outer函数,并且将其下面的函数名b1作为参数。
2.将outer函数的返回值,重新赋值给b1,上述代码outer的返回值就是inner()函数体,这个是重点!也就相当于print "logging...." + func(),而func() == 老b1(),故,新的b1()就是print "logging......" + print "b1......"
3.装饰器的用途就是可以在不改变原函数的情况下给函数增加功能。
2.被装饰函数有返回值
def outer(func):
def inner():
print("logging....")
# func()
ret = func()
return ret
return inner
@outer
def b1():
return "I love Python"
def b2():
print("b2.......")
def b3():
print("b3.......")
a = b1()
print(a)
执行结果如下:
logging....
I love Python
代码剖析:装饰器的用法不多说,上述例子已说明,详细说明一下和上个例子的不同之处
当函数有返回值时,同样inner()方法就相当于b1(),也就是说inner()函数的返回值就是老b1()的返回值。inner()函数的返回值就是ret,也就是老b1()的返回值,也就是"I love Python"
3.被装饰的函数有参数
def outer(func):
def inner(number):
print("logging....")
# func()
ret = func(number)
return ret
return inner
@outer
def b1(num):
return num * num
def b2():
print("b2.......")
def b3():
print("b3.......")
a = b1(9)
print(a)
执行结果如下
logging....
81
代码剖析:当被装饰的函数有参数时,一定要铭记一点,装饰器函数的内层函数就相当于被装饰的函数。那么如例子:b1()函数就相当于inner()函数,因为b1()在调用时有参数,并返回参数的平方。这里就需要在inner()函数增加参数,如题是写成inner(number)。而在这里,同样可以写成inner(*args,**kwargs)的万能参数的形式。
4.场景举例
LOGIN = False
def outer(func):
def inner():
if LOGIN:
func()
else:
print("请登录!!!!!")
return inner
@outer
def message():
print("欢迎登陆")
exit()
def login(user,pwd):
if user == "liukai" and pwd == "123":
global LOGIN
LOGIN = True
message()
def main():
while True:
print("1:管理,2:登陆")
inp = input("请输入: ")
if inp == "1":
message()
elif inp == "2":
userinput = input("请输入用户名: ")
passwdinput = input("请输入密码: ")
login(userinput,passwdinput)
main()
执行结果如下:
1:管理,2:登陆
请输入: 1
请登录!!!!!
1:管理,2:登陆
请输入: 1
请登录!!!!!
1:管理,2:登陆
请输入: 2
请输入用户名: liukai
请输入密码: 123
欢迎登陆
代码剖析:当首次选择管理后,会因为LOGIN = False 而无限循环,当选择登陆并用户密码输入正确后,会调用message()函数,全局变量LOGIN变为True。而message()函数被outer装饰了,当LOGIN为True时,执行message()函数,当LOGIN为False时,打印重新登陆。
2.进阶
1.装饰器带参数
def base(num):
def outer(func):
def inner(number):
print("logging....")
print("--- [%s] ---" % num)
# func()
ret = func(number)
return ret
return inner
return outer
@base("123")
def b1(num):
return num * num
def b2():
print("b2.......")
def b3():
print("b3.......")
a = b1(9)
print(a)
执行结果如下
logging....
--- [123] ---
81
代码剖析:对于无参数的装饰器,其装饰器函数的参数是要被装饰的函数名,对于有参数的装饰器在调用时使用的是传入的参数,所以必须在内部再定义一个函数outer()来接收要被装饰的函数对象。