文章目录

  • 前言
  • 函数
  • 1. 特点
  • 2. 格式
  • 3. 参数的使用
  • ① 位置参数---形参顺序与实参顺序相同,缺/多一不行
  • ② 关键字参数---指明参数,缺/多一不行
  • ③ 默认参数---默认参数值
  • ④ 混合参数使用---位置参数必须在关键字参数左边,不能位置与关键字参数重复
  • 4. 全局变量与局部变量(PS)
  • ① 先从内部找,找不到再从外部找
  • ② 如果函数的内容无global关键字,优先读取局部变量,若无则读取全局变量,能读取全局变量,但无法对全局变量进行重新赋值,但可变类型可以对内部元素进行操作。
  • ③ 如果函数中有global关键字,变量本质上是全局的那个变量,可读取可赋值。
  • ④ name = ‘a’ global name 此形式为错误形式。
  • ⑤ 局部前加global变量名,只改变最外边变量,使之变化,靠近的不受影响。
  • 5. 函数魔法与列表字典魔法连接
  • ① *列表
  • ② **字典
  • ③ 混合使用
  • 6. 递归函数魔法---自己调用本身函数匿名函数
  • 7. 匿名函数函数作用域
  • 8. 函数作用域高阶函数
  • 9. 高阶函数
  • ① 把函数当作参数传给另一个函数
  • ② 返回值中包含函数
  • 10. 三大高级函数
  • ① map()---处理序列中每个元素,得到的结果是一个列表,该列表元素个数及位置与原来一样
  • ② filter()---遍历序列中的每个元素,判断每个元素得到布尔值,若True则留下来reduce()---处理一个序列,然后靶序列进行合并并操作
  • ③ reduce()---处理一个序列,然后靶序列进行合并并操作
  • 11. 内置函数(之前出现的就略过了)
  • ① abs()---绝对值,hex(),oct(),bin()---二进制转十六,八,二进制
  • ② str(),type()---转化为字符串,类型查看
  • ③ bool()---布尔值(空,None,0的布尔值为False,其余全为True)
  • ④ all()---若为空,为True;全真为True;只能有一个参数或参数值
  • ⑤ any()---有一个真即为True
  • ⑥ bytes(),encode(),decode()---编码,编码,解码
  • ⑦ chr(),ord()---转化为对应ASCII编码,ASCII编码转化为对应值
  • ⑧ dir()---查看某一个对应下面的所对应的方法,help()---查看方法的使用方法
  • ⑨ divmod()---取商得余数,可做分页功能,divmod(总内容,每页内容数)-->(n,m)所需页数n+m
  • ⑩ eval()---将字符串中的数据结构提取出来,将字符串中的数学运算进行运算得到计算结果
  • ⑪ 11.hash()---可hash的数据类型即不可变类型,反之相反特性:
  • ⑫ vars()---无参数数时调用等于locals,有参数是时,参看某方法的使用方法以字典形式打印
  • ⑬ isinstance()---判断前者是否为后者的的类型
  • ⑭ globals(),local()---全局变量,局部变量
  • ⑮ zip()---压缩提取
  • ⑯ import---导入模块,不能导入字符串,__import__(),可以导入字符串
  • ⑰ reversed()---顺序反转,不影响原来列表
  • ⑱ slice()---切片
  • ⑲ max(),min()---最大最小值,pow()---次幂函数
  • ⑳ sorted()---排序,数字从大到小,不能混合字符串数字
  • 12. 风湿理论
  • 创建函数--->创建变量
  • 调用函数--->print变量
  • 总结



前言

函数魔法,是每一个Python Magic学员所必须掌握的魔法,无论在实战还是练习中都是必不可少的,若使用大型魔法,它可使其大型魔法变得非常容易施展,省去了复杂的招式,而且以后在使用该魔法会更加轻松。


函数

1. 特点

① 减少代码的重用。
② 保持一致性,易维护。
③ 可扩展性。

2. 格式

# def 函数名(参数):   #可以不加参数,将参数加到函数内部
#     语句块         
#     return x        #返回值,函数结束标志,可有可无
# 函数名(参数)   #函数调用

对于return返回值,返回值是一个整体:
return 值=0,返回none;
return 值=1,返回object类型;
return 值>1,返回tuple元组类型。

3. 参数的使用

① 位置参数—形参顺序与实参顺序相同,缺/多一不行
def cals(x,y):
    res = x**y
    return res
c = cals(2,3)
d = cals(3,2)   #位置参数顺序不同,结果不同
#e = cals(2,3,4)  多则报错
#f = cals         少则报错
print(c,d)
② 关键字参数—指明参数,缺/多一不行
def cals1(x,y):
    res = x**y
    return res
c = cals1(x=2,y=3)
d = cals1(y=2,x=3)   #参数指明不同结果不同
#e = cals1(y=2,y=3)  参数指明重复,错误
print(c,d)
③ 默认参数—默认参数值
def cals2(x,y=3):   #默认参数y=3
     res = x**y
     return res
c = cals2(x=2)      #未调用则使用默认参数
d = cals2(x=2,y=4)  #关键字参数重新赋值
e = cals2(2,4)      #位置参数重新赋值
print(c,d,e)
④ 混合参数使用—位置参数必须在关键字参数左边,不能位置与关键字参数重复
def cals2(x,y):   #默认参数y=3
      res = x**y
      return res
#c = cals2(x=2,3)      #关键字参数在左,位置参数在右,报错
d = cals2(2,y=4)  #关键字参数在右,位置参数在左
#e = cals2(2,x=2)      #位置与关键字参数重复,报错
print(d)

4. 全局变量与局部变量(PS)

① 先从内部找,找不到再从外部找
② 如果函数的内容无global关键字,优先读取局部变量,若无则读取全局变量,能读取全局变量,但无法对全局变量进行重新赋值,但可变类型可以对内部元素进行操作。
③ 如果函数中有global关键字,变量本质上是全局的那个变量,可读取可赋值。
④ name = ‘a’ global name 此形式为错误形式。
⑤ 局部前加global变量名,只改变最外边变量,使之变化,靠近的不受影响。
name = 'wxt'  #全局变量
def w():
    name = 'lhm'  #局部变量
    def q():
        global name   #与下面互换顺序报错PS④
        name = 'love'
    q()
    print(name)
print(name)
w()
print(name)

name1 = [1,2,3]
def m():
    n = 520
    def e():
        name1.append(n)  #PS②
        print(name1)
    e()
m()

5. 函数魔法与列表字典魔法连接

① *列表
def text(x,*y):  #x,只取第一个元素,*y,将后面组成列表,循环遍历输出
     print(x)
     print(y)
text(1,2,3,4,5)
text(1,[2,3,4,5])
text(1,*['2','3',4,5]) #列表的列表等于本身
② **字典
def text(x,**y):  #x,只取第一个元素,**args,将后面组成字典
     print(x)
     print(y)
text(1,g=2,z=3)  #字典对应模式
③ 混合使用
def text(x,*y,**z):  #只有这一种写法
     print(x)
     print(y)
     print(z)
text(1,2,3,m=1,n=2)
text(1,*[2,3],**{'y':2})

6. 递归函数魔法—自己调用本身函数匿名函数

def calc(n):                    #print(10)-->calc(5)-->print(5)-->calc(2)
     print(n)                   #-->print(2)-->calc(1)-->print(1)
     if int(n/2)==0:
          return n
     return calc(int(n/2))
calc(10)

7. 匿名函数函数作用域

#lambda 形参:处理逻辑(简单逻辑,一行搞定)
a = lambda x:x+1
b = lambda x:x in 'love'
print(a(5),b('o'))

8. 函数作用域高阶函数

def foo():
     name = 'love'
     def bar():
          name = 'wxt'
          def tt():
               def aa():
                   print('lhm')
               aa()
               print(name)
          return tt()    #加括号==调用函数
     return bar          #不加括号==返回函数地址

print(foo,foo())#返回函数地址
ba = foo()#调用foo()函数
ba()      #调用foo()函数中仅次于foo()函数的内置函数bar()
foo()()   #等同于上面两行

9. 高阶函数

① 把函数当作参数传给另一个函数
def foo(n):
     print(n)
def bar(name):
     return 'I love %s' %name
foo(bar('wxt'))#先里后外
② 返回值中包含函数
def bar():
     print('from bar')
def foo():
     print('from foo')
     return bar
n = foo()  #调用foo()函数将结果赋给n(返回值为bar()函数的函数地址)
n()  #调用bar()函数

def bar1():
     print('from bar1')
def bar2():
     print('from bar2')
     return bar1()
bar2()  #调用bar()函数,其中bar2()函数中返回bar1()的调用

10. 三大高级函数

① map()—处理序列中每个元素,得到的结果是一个列表,该列表元素个数及位置与原来一样
num = [1,2,3]
a = map(lambda x:x+1,num)   #num中元素迭代到前面函数,将运行结果存入列表
print(a)        #得到列表结果地址
print(list(a))  #list()获取列表的值

num1 = ['l','o','v','e']
a1 = map(lambda x:x+'520',num1)
print(a1)
print(list(a1))
② filter()—遍历序列中的每个元素,判断每个元素得到布尔值,若True则留下来reduce()—处理一个序列,然后靶序列进行合并并操作
num = ['005','lhm','lkm']
a = filter(lambda x:x.startswith('l'),num) #num中元素迭代到前面函数,将运行结果为True的存入列表
print(a)  #得到列表结果地址
print(list(a))  #list()获取列表的值

num1 = [0,5,25,2]
a1 = filter(lambda x:x>2,num1)
print(a1)
print(list(a1))
③ reduce()—处理一个序列,然后靶序列进行合并并操作
from functools import reduce
a = reduce(lambda x,y:x+y,range(10))    #没初始化值,默认为0,0+0+1+。。。+9
b = reduce(lambda x,y:x+y,range(10),6)  #初始化值,初始值为6开始,6+0+1+。。。+9
print(a,b)

11. 内置函数(之前出现的就略过了)

① abs()—绝对值,hex(),oct(),bin()—二进制转十六,八,二进制
a1,a2,a3 = -1,2,0
print(abs(a1),abs(a2),abs(a3))
b1 = 6
print(bin(b1),oct(b1),hex(b1))
② str(),type()—转化为字符串,类型查看
h1 = 520
h2 = str(h1)
print(h2)
print(type(h1),type(h2))
③ bool()—布尔值(空,None,0的布尔值为False,其余全为True)
print(bool(''),bool(None),bool(0))
print(bool(['l']),bool('abc'),bool(520))
④ all()—若为空,为True;全真为True;只能有一个参数或参数值
print(all(''),all([5,2,0]),all('wxt'))
⑤ any()—有一个真即为True
print(any([5,2,0]),any('lhm'),any(''))
⑥ bytes(),encode(),decode()—编码,编码,解码
name = 'wxt'
print(name.encode('utf-8'))  #encode()编码
print(name.encode('utf-8').decode('utf-8'))  #decode()解码,前后编码解码方式一致
print(bytes(name,encoding='utf-8'))
print(bytes(name,encoding='utf-8').decode('utf-8'))  #前后编码解码方式一致
⑦ chr(),ord()—转化为对应ASCII编码,ASCII编码转化为对应值
print(chr(98),ord('a'))
⑧ dir()—查看某一个对应下面的所对应的方法,help()—查看方法的使用方法
print(dir(list()))
print(help(list()))
⑨ divmod()—取商得余数,可做分页功能,divmod(总内容,每页内容数)–>(n,m)所需页数n+m
print(divmod(10,3))
⑩ eval()—将字符串中的数据结构提取出来,将字符串中的数学运算进行运算得到计算结果
a = [1,2,3]
print(eval(a))
print(eval('5+7'))
⑪ 11.hash()—可hash的数据类型即不可变类型,反之相反特性:

a. 传入参数与传出hash长度无关,hash定长
b. 不可反推hash
c. 可检测软件是否植入木马,只能软件不变,在任何地方或情况下hash不变

m = 'love'
print(hash(m))
print(hash(m))
m = m+'wxt'
print(hash(m))
⑫ vars()—无参数数时调用等于locals,有参数是时,参看某方法的使用方法以字典形式打印
print(vars())
print(locals())
print(vars(str))
⑬ isinstance()—判断前者是否为后者的的类型
print(isinstance(1,int),isinstance(2,str))
⑭ globals(),local()—全局变量,局部变量
print(globals())
print(locals())
⑮ zip()—压缩提取
d1 = list(zip(('w','x','t'),(5,2,0)))  #前后长度相同
d2 = list(zip(('w','x','t'),(5,2,0,0,0)))  #若不同,则省略后面数据
print(d1,d2)  #前后对应合并

d3 = {'name':'wxt','age':19}
d4 = list(zip(d3.keys(),d3.values()))  #对应合并
print(d4)
⑯ import—导入模块,不能导入字符串,import(),可以导入字符串
import time
print(time)
⑰ reversed()—顺序反转,不影响原来列表
e1 = ['l','o','v','e',5,2,0]
print(reversed(e1))  #直接调用返回的是列表地址
print(list(reversed(e1)))  #list()使其成为列表
⑱ slice()—切片
f1 = 'love'
f2 = ['love',520]
print(slice(f1))  #前后None补充
print(slice(f2))
⑲ max(),min()—最大最小值,pow()—次幂函数
print(max([5,2,0]),min([5,2,0]))
print(pow(2,10),pow(2,10,5))  #2**10   2**10%5
⑳ sorted()—排序,数字从大到小,不能混合字符串数字
g1 = [5,2,0]
print(sorted(g1))

g2 = {'a':120,'b':520,'c':666}
print(sorted(g2,key=lambda key:g2[key]))  #排序出key所对应的value大小顺序

12. 风湿理论

创建函数—>创建变量
调用函数—>print变量

总结

函数魔法的相关知识就简单说这些,还不赶快去学习!