目录
一.函数二.命名空间三.匿名函数1.函数定义
# 定义一个函数: def my_len(): 函数体 # def 关键字 -- 定义 # func 函数名 -- 和变量定义规则一样 # () 必须要写格式 # : 声明语句结束2.参数
# 形参: 函数的定义中括号里是形参 # 实参: 函数的调用括号里是实参 # 位置传参时 形参和实参必须一一对应 # 传参: 将实参传递给形参的过程就是传参 1.位置参数 def fun(a,b): print(a,b) fun("A","B") 2.默认参数 def fun2(a=1,b=2): pass # fun2() #不传参,默认打印1,2 # fun2(a=10,b=20) #传参,覆盖 3.混合参数(位置参数必须在默认参数前面) def fun3(a,b,c=1): print(a,b) fun3(1,2,c=10)3.动态参数
#参数优先级:位置参数>动态参数>默认参数>动态关键字 ''' def fun(a,b,*args,c=1,d=2,**kwargs): print(a,b,args,c,d,kwargs) fun(1,2,3,4,e=5,f=6) #1 2 (3,4) 1 2 {e:5,f:6} ''' 1.动态位置参数 --函数定义时星号加变量(*args)将传入的值聚合为元组赋值给变量args,在函数内部使用时星号加变量(*args)为打散 def fun(*args): print(args) #打印元组, (1,2,3) print(*args) #打散 1,2,3 fun(1,2,3) 2.动态默认参数 --函数定义时双星号加变量(**kwargs)将传入的关键参数聚合为字典赋值给变量kwargs,在函数内部使用星号加变量(*kwargs)将键打散 def fun(**kwargs): print(kwargs) #{"a":1,"b":2} print(*kwargs) #打散键 a b #print(**kwargs) #错误示范 fun(a=1,b=2) 3.动态参数混合 -优先级:位置参数>默认参数 def fun(*args,**kwargs): print(args,kwargs) #(1,2) {"a":1,"b":2} fun(1,2,a=1,b=2) 4.其他 dic = {"key":1,"key1":34} def func(**kwargs): print(kwargs) func(**dic) #此处将dic散开成key=1,key1=34 lst = [1,2,3,4] def fun(*args): print(args) fun(*lst) #此处将lst打散成1 2 3 4传入4.return返回值(终止的是函数,非for循环)
1. def fun(): print("你好") print(fun()) #fun()调用函数执行print("你好"),没有return,返回None # 打印结果: # 你好 None5.函数的注释
1.添加注释:在函数内部打上6个引号('''''' or """""")回车即可。 def func(a,b): """ 逻辑判断... :param a: str :param b: int :return: bool """ print(a,b) 2.查看注释 print(fun.__doc__)6.global和nonlocal
1.global:修改全局变量(修改最外层全局变量的值,而非上一层的) a = 1 def fun1(): a = 2 def fun2(): a = 3 def fun3(): global a a +=1 fun3() fun2() fun1() #执行结果 a=2 #由上个例子可知:无论嵌套多深,global只修改最外层全局变量的值 2.nonlocal:修改局部变量(修改最近的上一层变量,如果上一层没有找到,则继续向上找,直到第一层函数) a = 1 def fun1(): a =2 def fun2(): def fun3(): nonlocal a a += 1 fun3() fun() fun1() # fun1()中的a找上层fun2(),没有,继续向上找,fun1()中有,如果fun1()中如果没有,报错1.匿名函数定义
def 用来定义有名函数; lambda 用来定义无名函数 结构: lambda 参数:函数体 (lambda函数默认有返回值)2.lambda函数使用原因
#我们先简单定义一个函数 def foo(x,y): return x**y #下面使用lambda函数重新定义上面的函数 f = lambda x,y:x**n #此处默认就是return x**n print(f(2,2)) #打印结果 4 #ps:2 f = lambda x,y:print(x**y) print(f(2,2)) #打印结果 4 None #因为lambda函数有默认返回值,此处函数体中有print(),外部调用返回None3.lambda函数的应用场景
#max,min,sorted,map,filter,reduce 1.max() --得到下列字典中薪酬最多的人名 s1 = {"egon":3000,"alex":100000,"wupeizhi":1000,"yuanhao":200} ...调用有名函数 def fun(k): return s1[k] max(s1,key=fun) ...调用匿名函数 max(s1,key=lambda x:s1[x]) #简述上方调用有名函数: ''' max()中默认参数是一个序列,如果没有key值,就是按照s1取大小,并返回最大值;如果有key,就是按照key值来取大小,但同样返回s1中的值。此处将循环s1,将得到的值依次作为参数传递给fun()函数,max()函数就是比较key中值的大小,并返回对应的s1中的值。 ''' 2.sorted() --按照列表中数据的平方来排序 lst = [1,4,3,-6,9,2] print(sorted(lst,key = lambda x:x**2)) #打印结果:[1, 2, 3, 4, -6, 9] #简述上述方法: ''' sorted()本来返回排序好的列表序列,此处将lst遍历循环,同时将每个值作为参数传递给lambda函数中的x,比较x的平方的大小 因为1**2 < 2**2 < 3**2 < 4**2 < -6**2 <-9**2,因此返回列表[1, 2, 3, 4, -6, 9] ''' 3.map() 映射(对每个值进行操作) --将lst列表中的每个值平方 lst = [1,2,4,6] res = map(lambda x:x**2,lst) #将lst列表中每个值传给lambda函数,返回平方后的值 print(list(res)) --拼接_SB,最后一个_NB lst1 = ["小芳","大狗","王丹","黎明"] res = map(lambda x:x+"_NB" if x == "黎明" else x+"_SB",lst1) print(list(res)) #["小芳_SB","大狗_SB","王丹_SB","黎明_NB"] 4.reduce 拼接(迭代拼接) from functools import reduce --1到100相加 res = reduce(lambda x,y:x + y,range(1,101),0) #将0作为初始值与函数中的1相加,得到结果再与函数中的下个数相加,依次类推 --拼接下列列表为字符串 lsts = ["my","xx","42","fg","s2"] reduce(lambda x,y:x+y,lsts) #将lsts中的第一二个值作为参数传递给x,y,得到的结果再与lsts中第三个数拼接,依次类推 print(reduce(lambda x,y:x+y,lsts)) #'myxx42fgs2' 5.filter() 过滤 --过滤下面列表中大于2的数 lsts = [4,2,1,5,62,1,0] filter(lambda x:x>2,lsts) print(list(filter(lambda x:x>2,lsts))) #[4,5,62]转载于:https://www.cnblogs.com/gaoyukun/p/11196845.html