lambda匿名函数sorted排序函数filter过滤函数map映射函数
lambda函数:表示匿名函数,不需要def来声明,一句话就能搞定。
语法:函数名=lamda 参数:返回值
求10的10次方
f=lambda n:n**n
print(f(10))
注意:
函数名可以是多个,用逗号隔开
匿名函数只能写一行,当逻辑结束之后就直接返回数据。
返回值和正常函数一样,可以是任意数据
返回较大的那个数
user=lambda x,y:max(x,y)
print(user(2,1)) 多个数字,返回最大值
user = lambda *args:max(args)
sorted()函数:排序函数
语法:sorte(lterable,key =none ,reverse=False)
lterable:可迭代对象
key:sorted函数内部会把可迭代对象中的每一个元素拿出来交给后面的key
后面的key计算出一个数字. 作为当前这个元素的权重, 整个函数根据权重进行排序
reverse:是否倒序,True,倒序,False正序
lst = [
{'name':"汪峰","age":48},
{"name":"章子怡",'age':38},
{"name":"alex","age":39},
{"name":"wusir","age":32},
{"name":"赵一宁","age":28}
]
li=sorted(lst,key=lambda el :len(el["name "]),reverse=True)
print(li)
filter()筛选函数
语法:filter(function,lterable)
function:用来筛选函数,在filter中,把iterable中的元素传递给function,然后根据function返回的 True或者False来判断是否保留此项数据
iterable:可迭代对对象
lst = ["张无忌", "张铁林", "赵一宁", "石可心","马大帅"]
f = filter(lambda el:el[0]!="张",lst)
print('_iter_'in dir(f))
for el in f :
print(el)
筛选掉姓张的人
lst = [
{"name":"汪峰", "score":48},
{"name":"章子怡", "score":39},
{"name":"赵一宁","score":97},
{"name":"石可心","score":90}
]
f = filter(lambda el:el["score"] <60,lst)
print(list(f ) ) 筛选掉60分以下的人
map()
映射函数
语法:map(function,iterable)对可迭代对象的每一个元素进行映射,分别取执行function
print(list(map(lambda x:x*x,[1,2,3,4])))
利用映射函数来求x的x 次幂
算两个相同位置的列表的和
lst=[1,2,3,4,5]
lst1=[2,4,6,8,10]
print(list(map(lambda x, y: x+y,lst,lst1)))
递归
在函数中调用函数本身,就是递归,相当于贪吃蛇
在python中,递归最深是1000
我们可以利用递归来遍历各种树形结构
遍历一个文件夹
import os#引入模块
def func(wjm):
wj=os.listdir(wjm)#打开要打开的文件夹
for el in wj :#拿到这个文件夹的每一个文件
n_f=os.path.join(wjm,el )#获取到路径
if os.path .isdir(n_f):#判断是否是文件夹
print(el)#是文件夹打印问价名
func(n_f)
else:
print(el )#不是文件,普通文件
func("f:/上课作业视频")
二分法查找
核心:去头去尾取中间
条件:必须是有序的
lst = [22, 33, 44, 55, 66, 77, 88, 99, 101 , 238 , 345 , 456 , 567 , 678 , 789] n=888
zb=0
yb=len(lst)-1
while zb<=yb:
zj=(zb+yb)//2
if lst[zj]>n:
yb=zj-1
if lst[zj]<n:
zb=zj +1
if lst[zj]==n:
print("找到了")
break
else:
print("没找到")
用递归来完成二分法
def func(n,zb,yb):
if zb<=yb:
zj=(zb+yb)//2
if lst[zj]>n:
yb=n-1
return (n,zb,yb)
if lst[zj]<n:
zb=zb+1
return (n,zb,yb)
elif n==lst[zj]:
print("找到了")
return zj
else:
print("没有这个数")
ret=func(99,0,len(lst)-1)
print(ret)
lambda匿名函数sorted排序函数filter过滤函数map映射函数的更多相关文章
- python高阶函数——sorted排序算法
python 内置的sorted()函数可以对一个list进行排序: >>> sorted([8,3,8,11,-2]) [-2, 3, 8, 8, 11] 既然说是高阶函数,那么它 ...
- lambda匿名函数,sorted排序,filter()筛选,map()映射
一丶匿名函数 语法: 函数名 = lambda参数:返回值 # 普通的正常的函数 def func(n): return n * n ret = func(9) print(ret) # 匿名函数 a ...
- python学习笔记1 -- 函数式编程之高阶函数 sorted排序
python提供了很强大的内置排序函数,妈妈再也不担心我不会写冒泡排序了呀,sorted函数就是这个排序函数,该函数参数准确的说有四个,sorted(参数1,参数2,参数3,参数4). 参数1 是需要 ...
- php自带的filter过滤函数
PHP 过滤器用于对来自非安全来源的数据(比如用户输入)进行验证和过滤. filter_has_var()检查是否存在指定输入类型的变量. filter_id()返回指定过滤器的 ID 号. filt ...
- Python_Mix*匿名函数,sorted,filter,map,递归函数,二分法查找
lambda匿名函数(函数名统一都叫lambda) 为了解决简单的需求而设计的一句话函数 语法: lambda 参数 返回值 n = lambda a,b: max(a,b) ret = n(9,4) ...
- 019.Python函数sorted,filter和推导式
一 sorted函数 sorted(iterable,reverse=False,key=函数) 功能:排序 参数: iterable:可迭代性数据(常用:容器类型数据,range对象,迭代器) re ...
- python高阶函数sorted
原文 排序也是在程序中经常用到的算法.无论使用冒泡排序还是快速排序,排序的核心是比较两个元素的大小.如果是数字,我们可以直接比较,但如果是字符串或者两个dict呢?直接比较数学上的大小是没有意义的,因 ...
- lambda匿名函数,sorted(),filter(),map(),递归函数
1.lambda匿名函数 为了解决一些简单的需求而设计的一句话函数 #计算n的n次方 def func(n): return n**n print(func(10)) f = lambda n: n* ...
- 匿名函数lambda,过滤函数filter,映射类型map
匿名函数lambda, 作用是不用定义函数,用完之后会自动被删掉,在使用执行脚本的时候,使用lambda就可以省下定义函数的过程,简化代码的可读性. 格式是 例子g=lambda x,y:x+y g( ...
随机推荐
- 阶段3 1.Mybatis_07.Mybatis的连接池及事务_4 mybatis中使用unpooled配置连接池的原理分析
把之前的CRUD的代码src下的代码都复制过来 依赖项也都复制过来, 配置文件 整理一番 执行findAll方法的测试 查看日志的输出部分 修改程序池 再来执行findAll方法 Plooled从连接 ...
- Monkey测试:日志信息分析
在跑monkey时,我们需要将日志输出到文件,然后对日志信息进行分析. 一.输出日志到文件 在monkey命令后加>文件地址 如:adb shell monkey 1000>E:/text ...
- 基于Python对象引用、可变性和垃圾回收详解
基于Python对象引用.可变性和垃圾回收详解 下面小编就为大家带来一篇基于Python对象引用.可变性和垃圾回收详解.小编觉得挺不错的,现在就分享给大家,也给大家做个参考. 变量不是盒子 在示例所示 ...
- Dubbo分布式服务框架入门(附工程)
要想了解Dubbo是什么,我们不防先了解它有什么用. 使用场景:比如我想开发一个网上商城项目,这个网上商城呢,比较复杂,分为pc端web管理后台,微信端销售公众号,那么我们分成四个项目,pc端网站,微 ...
- visual studio 在windows远程调试 linux 程序 cout 输出乱码
转载:https://www.cnblogs.com/findumars/p/6627255.html 反正是解决了. 以gcc为例,它有三个命令选项:-finput-charset=gb18030- ...
- Nginx/Nginx基础学习
Nginx与node.js 一.Nginx与Node.js Nginx是一款轻量级的HTTP服务器,采用事件驱动的异步非阻塞处理方式框架,这让其具有极好的IO性能,时常用于服务端的反向代理和负载均衡. ...
- 20191128 Spring Boot官方文档学习(9.9)
9.9.数据存取 Spring Boot包含许多用于处理数据源的启动器. 9.9.1.配置自定义数据源 要配置自己的DataSource,请在配置中定义该类型的@Bean.Spring Boot可以在 ...
- ELk架构解析和部署
目录 一.什么是elk. 1 二.ELK 常用架构及使用场景介绍... 2 1.最简单架构... 2 2.以Logstash 作为日志搜集器... 2 3.以Beats 作为日志搜集器... 3 4. ...
- Linux-SSH远程管理服务实战
figure:first-child { margin-top: -20px; } #write ol, #write ul { position: relative; } img { max-wid ...
- Linux操作系统目录一览表
/ // 根目录 /bin //存放必要的命令 比如ls.cp.mkdir等命令 /boot //存放内核以及启动所需的文件 /dev //存放硬件设备文件 比如声卡.磁盘.光驱 /etc //存放系 ...