博客
关于我
Python学习(八)——map、reduce、filter、sorted
阅读量:157 次
发布时间:2019-02-27

本文共 1650 字,大约阅读时间需要 5 分钟。

map

map()函数接收两个参数:一个函数,一个序列;map函数将传入函数依次作用于序列的每个元素,把结果作为新的list返回。

将list内的元素转换为数字

>>> map(int,['1', '2', '3', '4', '5', '6', '7', '8', '9'])[1,2,3,4,5,6,7,8,9]

将list内的数字转换为str

>>> map(str,[1,2,3,4,5,6,7,8,9])['1', '2', '3', '4', '5', '6', '7', '8', '9']

求list内元素的绝对值:

>>> map(abs,[-12,-8,2,-9,61,-27])[12, 8, 2, 9, 61, 27]

普通函数实现:

>>> def add(a,b):    return 10*a+b>>> reduce(add,[1,2,3,4,5,6,7,8,9])123456789

reduce

reduce把一个函数f作用在一个序列上,函数f必须接收2个参数;reduce把序列中的抢两个元素传入到函数f中,计算结果接续和下一个元素组合传入函数f中,直到序列的最后一个元素。

>>> def fun(a,b):    return a+b+2>>> reduce(fun,[3,2,1,6,5,4,9,8,7])61
>>> def add(a,b):    return 10*a+b>>> reduce(add,[1,2,3,4,5,6,7,8,9])123456789

filter

filter()函数将传入函数依次作用于序列中的每个元素,返回值为True的元素则保留,False则丢弃,按此规律过滤序列。

滤除3的倍数:

>>> def f(n):    return n%3 !=0>>> filter(f,[1,2,3,4,5,6,7,8,9])[1, 2, 4, 5, 7, 8]

滤除质数:

>>> from math import >>> def notp(n):    if n>1:        for i in range(2,int(sqrt(n))+1):            if(n%i ==0):                return True                 elif n==1:        return True    else:        return False>>> filter(notp,[1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20])[1, 4, 6, 8, 9, 10, 12, 14, 15, 16, 18, 20]

sorted

sorted()函数对list进行排序:

>>> sorted([1,2,5,4])[1, 2, 4, 5]>>> sorted([12,45,3,45,78,3,23,4,0,321,235,64,63,1,231,32,1])[0, 1, 1, 3, 3, 4, 12, 23, 32, 45, 45, 63, 64, 78, 231, 235, 321]

sorted对字符串按ASCII大小进行排序:

>>> sorted(['Asc','cmp','w','Xi'])['Asc', 'Xi', 'cmp', 'w']

sorted是高阶函数,可以接收比较函数来自定义实现排序:

>>> def revers(x,y):    if x>y:        return -1    if x
>> sorted([12,45,3,45,78,3,23,4])[3, 3, 4, 12, 23, 45, 45, 78]>>> sorted([12,45,3,45,78,3,23,4],revers)[78, 45, 45, 23, 12, 4, 3, 3]

这里写图片描述

你可能感兴趣的文章
mysql5.7安装
查看>>
mysql5.7性能调优my.ini
查看>>
MySQL5.7新增Performance Schema表
查看>>
Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
查看>>
Webpack 之 basic chunk graph
查看>>
Mysql5.7版本单机版my.cnf配置文件
查看>>
mysql5.7的安装和Navicat的安装
查看>>
mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
查看>>
Mysql8 数据库安装及主从配置 | Spring Cloud 2
查看>>
mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
查看>>
MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
查看>>
MYSQL8.0以上忘记root密码
查看>>
Mysql8.0以上重置初始密码的方法
查看>>
mysql8.0新特性-自增变量的持久化
查看>>
Mysql8.0注意url变更写法
查看>>
Mysql8.0的特性
查看>>
MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
查看>>
MySQL8修改密码的方法
查看>>
Mysql8在Centos上安装后忘记root密码如何重新设置
查看>>
Mysql8在Windows上离线安装时忘记root密码
查看>>