内置函数
#作用域相关 print(globals()) print(locals())
#生成器/迭代器 l = [11,22,33,44] it = iter(l) #<list_iterator object at 0x01EA2910> 将列表变成迭代器 print(it) print(next(it)) print(next(it)) print(next(it)) print(next(it)) print(next(it)) #取到这里会报错,因为没有那个多值,报StopIteration
lamda匿名函数
lambda表示的是匿名函数. 不需要用def来声明, 一句话就可以声明出一个函数
语法:
函数名 = lambda 参数: 返回值
语法:
函数名 = lambda 参数: 返回值
注意:
1. 函数的参数可以有多个. 多个参数之间用逗号隔开
2. 匿名函数不管多复杂. 只能写一行, 且逻辑结束后直接返回数据
3. 返回值和正常的函数一样, 可以是任意数据类型匿名函数并不是说一定没有名字. 这里前面的变量就是这个函数名. 说他是匿名原因是我们通过func.__name__查看的时候是没有名字的. 统一都叫lambda. 在调用的时候没有什么特别之处.
1. 函数的参数可以有多个. 多个参数之间用逗号隔开
2. 匿名函数不管多复杂. 只能写一行, 且逻辑结束后直接返回数据
3. 返回值和正常的函数一样, 可以是任意数据类型匿名函数并不是说一定没有名字. 这里前面的变量就是这个函数名. 说他是匿名原因是我们通过func.__name__查看的时候是没有名字的. 统一都叫lambda. 在调用的时候没有什么特别之处.
像正常的函数调用即可
#返回多个值 def func(x,y): return x,y #这里返回的是一个元祖 #等同于 a = lambda x,y : (x,y)
这里如果写成a = lambda x,y : x,y,会报错,因lambda类似看成一个元祖,以逗号分隔,会把lambda x,y : x当一个值,y当一个值,然后y没有定义,所以报错,这里把要返回的值用括号括起来,形成一个元祖
#传两个参数,返回最大值 a = lambda x,y :max(x,y) print(a(4,5)) #传多个值 a = lambda *args :max(args) print(a(4,5,6,34,434,656,23,54,6,2,8,9))
排序函数
sorted()
排序函数.
语法: sorted(Iterable, key=None, reverse=False)
Iterable: 可迭代对象
key: 排序规则(排序函数), 在sorted内部会将可迭代对象中的每一个元素传递给这个函
数的参数. 根据函数运算的结果进行排序
reverse: 是否是倒叙. True: 倒叙, False: 正序
#sorted排序 l = ["3663","88888","44","333",'55',"2222","777"] ll = sorted(l) print(ll) # ['2222', '333', '3663', '44', '55', '777', '88888']
#需要根据字符串长度排序 def func(n): '''定义排序的方式,这里按字符串的长度''' return len(n)
#key:排序方式,sorted函数会把可迭代对象中的每一个元素拿出来交给后面的key, #后面的key计算出一个数字,作为当前这个元素的权重,整个函数会根据权重排序 ll = sorted(l,key=func) print(ll) # ['44', '55', '333', '777', '3663', '2222', '88888']
#倒序 reverse=True, reverse=False是正序 ll = sorted(l,key=func,reverse=True) print(ll) # ['88888', '3663', '2222', '333', '777', '44', '55']
使用lambda定义函数
#使用lambda定义函数 l = [{"name":"aaa",'age':34}, {"name":"ccc",'age':30}, {"name":"eee",'age':37}, {"name":"bbb",'age':35}] ll = sorted(l,key=lambda dic:dic["age"])
#lambda函数拆开看就是def fun(dic):
# return dic["age"] print(ll)
# [{'name': 'ccc', 'age': 30}, {'name': 'aaa', 'age': 34}, {'name': 'bbb', 'age': 35}, {'name': 'eee', 'age': 37}]
ll = sorted(l,key=lambda dic:dic["age"],reverse=True) #反序
print(ll) #[{'name': 'eee', 'age': 37}, {'name': 'bbb', 'age': 35}, {'name': 'aaa', 'age': 34}, {'name': 'ccc', 'age': 30}]
filter 过滤
筛选函数
语法: filter(function. Iterable)
function: 用来筛选的函数. 在filter中会自动的把iterable中的元素传递给function. 然后
根据function返回的True或者False来判断是否保留此项数据
Iterable: 可迭代对象
#filter l = ['aa',"anc",'ccc','aef','ddd','eee'] def func(e): '''当第一个是a返回F,不是a返回T''' if e[0] == 'a': return False #不想要的 else: return True f = filter(func,l) print(f) # <filter object at 0x006B40B0> print("__iter__" in dir(f)) # True 说明是可迭代对象 for i in f: print(i) ''' ccc ddd eee ''' #用lambda写 f = filter(lambda e:e[0] != "a",l) #lambda 返回为真的内容 print("__iter__" in dir(f)) # True 说明是可迭代对象 for j in f: print(j) ''' ccc ddd eee'''
过滤出某个范围内的数据
dic = [{"name":"aaa",'age':34}, {"name":"ccc",'age':30}, {"name":"eee",'age':37}, {"name":"bbb",'age':35}] #过滤出年龄大于34 f = filter(lambda e :e["age"] > 34,dic) print(type(f)) #<class 'filter'> print(list(f)) #[{'name': 'eee', 'age': 37}, {'name': 'bbb', 'age': 35}]
map()
映射函数
语法: map(function, iterable) 可以对可迭代对象中的每一个元素进行映射. 分别取执行
function
计算列表中每个元素的平方 ,返回新列表
#map映射 #计算列表中元素的平方 l1 = [1,2,3,4] a = map(lambda x:x**2,l1) print(list(a)) # [1, 4, 9, 16] #计算两个列表中相同位置元素的和 l1 = [1,2,3,4] l2 = [5,6,7,8] a = map(lambda x,y:x + y,l1,l2) print(list(a)) # [6, 8, 10, 12]
有水桶相应,某个列表少了,多了,都以少的为准
递归
在函数中调用函数本身. 就是递归
通过递归遍历某个文件夹下的内容
def func(): print("我是谁") func() func()
在python中递归的深度最⼤到998
def foo(n): print(n) n += 1 foo(n) foo(1)
递归的应用
我们可以使用递归来遍历各种树形结构, 比如我们的⽂件夹系统. 可以使⽤递归来遍历该
文件夹中的所有文件
#递归文件夹,函数内部调用外面的函数 import os def func(filepath,n): #打开指定文件夹 files = os.listdir(filepath) #获取到每一个文件名 for file in files: #获取到绝对路径,加⼊⽂件夹 获取到⽂件夹+⽂件 file_path = os.path.join(filepath,file) #判断是否是文件夹 if os.path.isdir(file_path): print(" "*n,"