019.Python函数sorted,filter和推导式
一 sorted函数
sorted(iterable,reverse=False,key=函数)
功能:排序
参数:
iterable:可迭代性数据(常用:容器类型数据,range对象,迭代器)
reverse : 是否倒序
默认正序reverse= False(从小到大) 如果reverse=True 代表倒序 (从大到小)
key = 自定义函数 或者 内置函数
返回值:
排序的序列
1.1 从小到大默认排序
listvar = [1,2,-88,-4,5]
# 从小到大默认排序
res = sorted(listvar)
print(res)
执行
[root@node10 python]# python3 test.py
[-88, -4, 1, 2, 5]
1.2 从大到小排序
listvar = [1,2,-88,-4,5]
res = sorted(listvar,reverse=True)
print(res)
执行
[root@node10 python]# python3 test.py
[5, 2, 1, -4, -88]
1.3 按照绝对值排序
需要用到内置函数abs(绝对值函数)
res = abs(-1.5)
print(res)
listvar = [1,2,-88,-4,5]
res = sorted(listvar,key=abs)
print(res)
执行
[root@node10 python]# python3 test.py
1.5
[1, 2, -4, 5, -88]
1.4 按照余数排列
listvar = [19,23,44,57]
def func(n):
return n % 10 res = sorted(listvar,key=func)
print(res)
listvar = [4,1,2,9]
listvar.sort()
print(listvar)
执行
[root@node10 python]# python3 test.py
[23, 44, 57, 19]
[1, 2, 4, 9]
sort 基于原有列表进行修改
sorted 是产生一个新列表
二 filter函数
filter(func,iterable)
功能:过滤数据
如果函数的返回值是True ,代表保留当前数据
如果函数逇返回值是False,代表舍弃当前数据
参数:
func 自定义函数
iterable 可迭代对象(常用:容器类型数据,range对象,迭代器)
返回值
迭代器
取出所有的偶数
listvar = [1,2,3,4,4,56,6,6,7,8,9,10]
# 要所有的偶数,舍弃所有的奇数
def func(n):
if n % 2 == 0:
return True
else:
return False it = filter(func,listvar)
res = list(it)
print(res)
执行
[root@node10 python]# python3 test.py
[2, 4, 4, 56, 6, 6, 8, 10]
使用匿名函数优化
listvar = [1,2,3,4,4,56,6,6,7,8,9,10]
# 要所有的偶数,舍弃所有的奇数 it = filter(lambda n :True if n % 2 == 0 else False,listvar)
print(list(it))
执行
[root@node10 python]# python3 test.py
[2, 4, 4, 56, 6, 6, 8, 10]
三 推导式
- 通过一行循环判断,遍历出一系列数据的方式是推导式 (简洁方便)
3.1 列表推导式
[1,2,3,4] => [2,4,6,8]
lst = []
for i in range(1,5):
print(i)
lst.append(i)
print(lst)
执行
1
2
3
4
[1, 2, 3, 4]
推导式写法
listvar = [i for i in range(1,5)]
print(listvar)
listvar = [i*2 for i in range(1,5)]
print(listvar)
执行
[root@node10 python]# python3 test.py
[1, 2, 3, 4]
[2, 4, 6, 8]
3.1.1 带有判断条件的列表推导式
[1,2,3,4,4,5,9,6] 只要奇数
lst = [1,2,3,4,4,5,9,6]
lst2 = []
for i in lst:
if i % 2 == 1:
lst2.append(i)
print(lst2)
#推导式写法
res = [i for i in lst if i % 2 == 1]
print(res)
执行
[root@node10 python]# python3 test.py
[1, 3, 5, 9]
[1, 3, 5, 9]
3.1.2 带有双循环的列表推导式
lst1 = [1,2,3]
lst2 = [4,5,6]
for i in lst1:
for j in lst2:
print("%d*%d=%2d " % (i,j,i*j))
#使用推导式
res = ["%d*%d=%2d " % (i,j,i*j) for i in lst1 for j in lst2]
print(res)
执行
[root@node10 python]# python3 test.py
1*4= 4
1*5= 5
1*6= 6
2*4= 8
2*5=10
2*6=12
3*4=12
3*5=15
3*6=18
['1*4= 4 ', '1*5= 5 ', '1*6= 6 ', '2*4= 8 ', '2*5=10 ', '2*6=12 ', '3*4=12 ', '3*5=15 ', '3*6=18 ']
3.1.3 带有条件判断的多循环推导式
使用两个列表,第一行的和第二行对应相乘
lst1 = [1,2,3]
lst2 = [4,5,6]
for i in lst1:
for j in lst2:
if lst1.index(i) == lst2.index(j):
print ("%d*%d=%2d " % (i,j,i*j))
res = ["%d*%d=%2d " % (i,j,i*j) for i in lst1 for j in lst2 if lst1.index(i) == lst2.index(j)]
print(res)
第一行的奇数和第二行的偶数相乘,并打印
lst1 = [1,2,3,4]
lst2 = [5,6,7,8]
for i in lst1:
for j in lst2:
if i % 2== 1 and j %2 == 0:
print ("%d*%d=%2d " % (i,j,i*j))
#是用推导式
res = ["%d*%d=%2d " % (i,j,i*j) for i in lst1 for j in lst2 if i % 2== 1 and j %2 == 0]
print(res)
执行
1*6= 6
1*8= 8
3*6=18
3*8=24
['1*6= 6 ', '1*8= 8 ', '3*6=18 ', '3*8=24 ']
推导式的后面:只能是循环或者 判断(单项分支 只有一个if 没有其他的了)
如果你需要这个值,就把这个值放到for的最左边.
3.2 集合推导式
setvar = {} 代表字典
() 代表空元祖
(1) 代表整型1
(1,) 代表元组
set() 代表空集合
案例:判断一个VIP会员
条件:(1)满足年龄在18到21,存款大于等于5000小于等于5500的人,
统计结果:尊贵VIP卡老x(姓氏),否则开卡格式为:普通会员老*(姓氏)
listvar = [
{"name":"王大宝","age":18,"money":10000},
{"name":"王二宝","age":19,"money":5100},
{"name":"王三宝","age":20,"money":4800},
{"name":"李大宝","age":21,"money":2000},
{"name":"李二宝","age":180,"money":20}
]
setvar = set()
print(type(setvar))
for i in listvar :
if 5000 <=i['money'] <= 5500 and 18 <= i['age'] <= 21:
setvar.add("尊贵vip老"+i['name'][0])
else:
setvar.add("普通会员卡老"+i['name'][0])
print(setvar)
#使用三目运算符+推导式
setvar={"尊贵vip老"+i['name'][0] if 5000 <=i['money'] <= 5500 and 18 <= i['age'] <= 21 else "普通会员卡老"+i['name'][0] for i in listvar} print(setvar)
执行
[root@node10 python]# python3 test.py
<class 'set'>
{'普通会员卡老王', '尊贵vip老王', '普通会员卡老李'}
{'普通会员卡老王', '尊贵vip老王', '普通会员卡老李'}
3.3 字典推导式
3.3.1 enumerate函数
enumerate(iterable,[start=0]) #start是一个可选对象
功能:枚举 ; 将索引号和iterable中的值,一个一个拿出来配对组成元组放入迭代器中
参数:
iterable: 可迭代性数据 (常用:迭代器,容器类型数据,可迭代对象range)
start: 可以选择开始的索引号(默认从0开始索引)
返回值:迭代器
案例
listvar = ["a","b","c","d"]
res = enumerate(listvar)
print (res)
执行
[root@node10 python]# python3 test.py
<enumerate object at 0x7f3c3f505750>
使用迭代器
listvar = ["a","b","c","d"]
res = enumerate(listvar)
print (res)
# Iterator 迭代器 Iterable 可迭代对象
from collections import Iterator,Iterable
print(isinstance(res,Iterator))
print(list(res))
执行
[root@node10 python]# python3 test.py
<enumerate object at 0x7f7851fc4750>
True
[(0, 'a'), (1, 'b'), (2, 'c'), (3, 'd')]
特别指定开始值是14 不是默认0
listvar = ["a","b","c","d"]
res = enumerate(listvar)
print (res)
# Iterator 迭代器 Iterable 可迭代对象
from collections import Iterator,Iterable
print(isinstance(res,Iterator))
print(list(res)) res = enumerate(listvar,start=14)
print(list(res))
执行
[root@node10 python]# python3 test.py
<enumerate object at 0x7f04d1b42708>
True
[(0, 'a'), (1, 'b'), (2, 'c'), (3, 'd')]
[(14, 'a'), (15, 'b'), (16, 'c'), (17, 'd')]
转换为字典
listvar = ["a","b","c","d"]
res = enumerate(listvar)
print (res)
# Iterator 迭代器 Iterable 可迭代对象
from collections import Iterator,Iterable
print(isinstance(res,Iterator))
print(list(res)) res = enumerate(listvar,start=14)
print(list(res),type(list(res)))
#转换
lst = [(14, 'a'), (15, 'b'), (16, 'c'), (17, 'd')]
res = dict(lst)
print (res)
执行
[root@node10 python]# python3 test.py
<enumerate object at 0x7f2f5ceb3750>
True
[(0, 'a'), (1, 'b'), (2, 'c'), (3, 'd')]
[(14, 'a'), (15, 'b'), (16, 'c'), (17, 'd')] <class 'list'>
{14: 'a', 15: 'b', 16: 'c', 17: 'd'}
使用enumrate实现字典推导式
listvar = ["a","b","c","d"]
res = enumerate(listvar)
print (res)
# Iterator 迭代器 Iterable 可迭代对象
from collections import Iterator,Iterable
print(isinstance(res,Iterator))
print(list(res)) res = enumerate(listvar,start=14)
print(list(res),type(list(res))) lst = [(14, 'a'), (15, 'b'), (16, 'c'), (17, 'd')]
res = dict(lst)
print (res) dictvar = {a:b for a,b in enumerate(listvar,start=9)}
print (dictvar)
执行
<enumerate object at 0x7f28329d1900>
True
[(0, 'a'), (1, 'b'), (2, 'c'), (3, 'd')]
[(14, 'a'), (15, 'b'), (16, 'c'), (17, 'd')] <class 'list'>
{14: 'a', 15: 'b', 16: 'c', 17: 'd'}
{9: 'a', 10: 'b', 11: 'c', 12: 'd'}
可以直接使用dict强转
listvar = ["a","b","c","d"]
res = enumerate(listvar)
print (res)
# Iterator 迭代器 Iterable 可迭代对象
from collections import Iterator,Iterable
print(isinstance(res,Iterator))
print(list(res)) res = enumerate(listvar,start=14)
print(list(res),type(list(res))) lst = [(14, 'a'), (15, 'b'), (16, 'c'), (17, 'd')]
res = dict(lst)
print (res) dictvar = {a:b for a,b in enumerate(listvar,start=9)}
print (dictvar) res = dict(enumerate(listvar,start=10))
print (res)
执行
<enumerate object at 0x7f54f8c10900>
True
[(0, 'a'), (1, 'b'), (2, 'c'), (3, 'd')]
[(14, 'a'), (15, 'b'), (16, 'c'), (17, 'd')] <class 'list'>
{14: 'a', 15: 'b', 16: 'c', 17: 'd'}
{9: 'a', 10: 'b', 11: 'c', 12: 'd'}
{10: 'a', 11: 'b', 12: 'c', 13: 'd'}
3.3.2 zip
zip(iterable, ... ...)
功能: 将多个iterable中的值,一个一个拿出来配对组成元组放入迭代器中
iterable: 可迭代性数据 (常用:迭代器,容器类型数据,可迭代对象range)
返回: 迭代器 # 注意:2个值得索引号需要相同,如果有余出的自动舍弃.
案例
from collections import Iterator,Iterable
list1 = ["a","b","c","d"]
list2 = [1,2,3,4,5,6,7,8,8,9,99,0,0]
it = zip(list1,list2)
print(isinstance(it,Iterator))
print(list(it))
#返回值 [('a', 1), ('b', 2), ('c', 3), ('d', 4)] # 利用zip实现字典推导式
dic = { k:v for k,v in zip(list1,list2) }
print(dic) # 利用dict 强转zip迭代器变成字典
res = dict(zip(list1,list2))
print(res)
执行
[root@node10 python]# python3 test.py
True
[('a', 1), ('b', 2), ('c', 3), ('d', 4)]
{'a': 1, 'b': 2, 'c': 3, 'd': 4}
{'a': 1, 'b': 2, 'c': 3, 'd': 4}
019.Python函数sorted,filter和推导式的更多相关文章
- 小学生都能学会的python(<lamda匿名函数,sorted(),filter(),map(),递归函数>)
小学生都能学会的python(<<lamda匿名函数,sorted(),filter(),map(),递归函数,二分法>> 1. lambda 匿名函数 lambda 参数: ...
- 『Python基础-12』各种推导式(列表推导式、字典推导式、集合推导式)
# 『Python基础-12』各种推导式(列表推导式.字典推导式.集合推导式) 推导式comprehensions(又称解析式),是Python的一种独有特性.推导式是可以从一个数据序列构建另一个新的 ...
- 记录我的 python 学习历程-Day12 生成器/推导式/内置函数Ⅰ
一.生成器 初识生成器 生成器的本质就是迭代器,在python社区中,大多数时候都把迭代器和生成器是做同一个概念. 唯一的不同就是: 迭代器都是Python给你提供的已经写好的工具或者通过数据转化得来 ...
- python笔记3 闭包 装饰器 迭代器 生成器 内置函数 初识递归 列表推导式 字典推导式
闭包 1, 闭包是嵌套在函数中的 2, 闭包是内层函数对外层函数的变量(非全局变量)的引用(改变) 3,闭包需要将其作为一个对象返回,而且必须逐层返回,直至最外层函数的返回值 闭包例子: def a1 ...
- python 三元表达式、列表推导式、生成器表达式、递归、匿名函数、内置函数
http://www.cnblogs.com/linhaifeng/articles/7580830.html 三元表达式.列表推导式.生成器表达式.递归.匿名函数.内置函数
- python之生成器和列表推导式
一.生成器函数 1.生成器 就是自己用python代码写的迭代器,生成器的本质就是迭代器(所以自带了__iter__方法和__next__方法,不需要我们去实现). 2.构建生成器的两种方式 1,生成 ...
- python note 12 生成器、推导式
1.生成器函数 # 函数中如果有yield 这个函数就是生成器函数. 生成器函数() 获取的是生成器. 这个时候不执行函数# yield: 相当于return 可以返回数据. 但是yield不会彻底中 ...
- 《Python》 生成器和列表推导式
一.初识生成器: 生成器就是自己用Python代码写的迭代器,生成器的本质就是迭代器. 1.Python中提供的生成器: 1.生成器函数: 使用yield语句而不是return语句返回结果.yield ...
- Python面试题之列表推导式
题目要求: 生成如下列表 [[0,0,0,0,0,],[0,1,2,3,4,],[0,2,4,6,8,],[0,3,6,9,12,]] (考察列表生成式和基本逻辑推理) 方法1: list1 = [] ...
随机推荐
- 使用Leaflet创建地图模块
背景 最近需要为某单位开发地图展示系统,因此开始涉略和使用Leaflet这个轻量级地图库. 创建基础地图需要以下几步 引入相关js和css文件,创建基础地图 <div id="map& ...
- 5. Mybatis UPDATE更新,DELETE删除
案例: 1. update <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper ...
- Salesforce学习之路(六)利用Visualforce Page实现页面的动态刷新功能
Visualforce是一个Web开发框架,允许开发人员构建可以在Lightning平台上本地托管的自定义用户界面.其框架包含:前端的界面设计,使用的类似于HTML的标记语言:以及后端的控制器,使用类 ...
- ASP.Net 管道模型 VS Asp.Net Core 管道 总结
1 管道模型 1 Asp.Net Web Form管道 请求进入Asp.Net工作进程后,由进程创建HttpWorkRequest对象,封装此次请求有关的所有信息,然后进入HttpRuntime类进 ...
- 753. Cracking the Safe
There is a box protected by a password. The password is n digits, where each letter can be one of th ...
- 数据库函数-常用的MySQL函数
1.date_sub() 时间的加减 备注:record 为datetime类型 select record_time as date, order_area as orderArea, order_ ...
- 关于YiII框架的扩展memcache中set设置时间就get查询失效的解决方案(版本是1.1.20)
0x01 前言 在使用Yii框架的扩展memcache缓存的时候,存储数据有一个set方法,来看一下set方法的原型: public boolean set(string $id, mixed $va ...
- Windows核心编程 第27章 硬件输入模型和局部输入状态
第27章 硬件输入模型和局部输入状态 这章说的是按键和鼠标事件是如何进入系统并发送给适当的窗口过程的.微软设计输入模型的一个主要目标就是为了保证一个线程的动作不要对其他线程的动作产生不好的影响. 27 ...
- Python爬虫之 正则表达式和re模块
什么是正则表达式: 通俗理解:按照一定的规则,从某个字符串中匹配出想要的数据.这个规则就是正则表达式.标准答案:https://baike.baidu.com/item/正则表达式/1700215?f ...
- Dockerfile多阶段构建
多阶段构建 之前的做法: 在Docker17.05版本之前,构建Docker镜像,通常采用两种方式: 1.全部放入一个Dockerfile 一种方式是将所有的构建过程全都包含在一个Dockerfile ...