map

map(function, list): 就是对list 中的每一个元素都调用function函数进行处理,返回一个map的对象

list一下就可以生成一个列表

或者for循环该对象就可以输出值

c=[2,3,4,5,6]
bb=list(map(lambda x:x+1,a))
print(bb)
[2, 3, 4, 5, 6]
a=[1,2,3,4,5]
c=[2,3,4,5,6]
bb=list(map(lambda x,y:(x+1,y+1),a,c))
print(bb)
输出:
其中x:y就是要输出的值对应了:后面的表达式
[(2, 3), (3, 4), (4, 5), (5, 6), (6, 7)]
dic=[{'id':1,'dd':''},{'id':2,'dd':''},{'id':3,'dd':''},]

haha=list(map(lambda x:(x.get('id')),dic))

print(haha)
输出:
[1, 2, 3]

zip

zip()是Python的一个内建函数,它接受一系列可迭代的对象作为参数,将对象中对应的元素打包成一个个tuple(元组),然后返回由这些tuples组成的list(列表)。若传入参数的长度不等,则返回list的长度和参数中长度最短的对象相同。利用*号操作符,可以将list unzip(解压)

a = [1,2,3]
b = [4,5,6]
c = [4,5,6,7,8]
zipped =list(zip(a,b)) print(zipped)
# [(1, 4), (2, 5), (3, 6)] print(list(zip(a,c)))
#[(1, 4), (2, 5), (3, 6)] print(list(zip(*zipped)))
#[(1, 2, 3), (4, 5, 6)]

filter

filter(function, list): 对list中的每一个元素都调用function进行判断,返回满足条件的元素列表。感觉它跟map很像,是的,但也有细微的差别,看下面代码就知道了。

#过滤符合条件的数据
a=[1,2,3,4,5]
data=list(filter(lambda x:x>2,a))
print(data)
输出:[3, 4, 5]

map是循环每个字段进行比较,得出的结果放在列表里:

a=[1,2,3,4,5]
data=list(map(lambda x:x>2,a))
print(data)
#输出[False, False, True, True, True]

列表生成器

当然我觉得列表生成器是很好用的工具

他能够帮我快速的构建数据

b=[1,2,3,4,5,6]
a=[ row+1 for row in b]
print(a)
[2, 3, 4, 5, 6, 7]

乍一看好像一样,但是如果你想对同一个数据构建两次呢?

b=[1,2,3,4,5,6]
a=[ (row+1,row*2) for row in b]
print(a)
[(2, 2), (3, 4), (4, 6), (5, 8), (6, 10), (7, 12)] ##############
b=[1,2,3,4,5,6]
a=[ [row+1,row*2] for row in b]
print(a)
[[2, 2], [3, 4], [4, 6], [5, 8], [6, 10], [7, 12]]
b=[1,2,3]
a=[ {'数值加1':row+1,'数值加2':row+2} for row in b]
print(a)
[{'数值加1': 2, '数值加2': 3}, {'数值加1': 3, '数值加2': 4}, {'数值加1': 4, '数值加2': 5}]

这种对queryset的循环会很爽;

# obj_list=[obj,obj,obj]

# result=[ obj.id for obj in obj_list]

# result=[ {'id':obj.id,'title':obj.title} for obj in obj_list]
values=[{'id':1,'title':'哈哈11'},{'id':2,'title':'哈哈2'},{'id':3,'title':'哈哈33'},]

dic = [{'id':row['id']} for row in values]

print(dic)
#[{'id': 1}, {'id': 2}, {'id': 3}]

当然还可以构造字典格式的:

values=[{'id':1,'title':'哈哈11'},{'id':2,'title':'哈哈2'},{'id':3,'title':'哈哈33'},]

dic = {row['id']: row  for row in values}

# dic = {row['id']:{'id':row['id'],'title':row['title']}  for row in values}
#两种表达其实都一样 print(dic)
#{1: {'id': 1, 'title': '哈哈11'}, 2: {'id': 2, 'title': '哈哈2'}, 3: {'id': 3, 'title': '哈哈33'}}

zip filter map 列表生成器的更多相关文章

  1. python一些内建函数(map,zip,filter,reduce,yield等)

    python一些内建函数(map,zip,filter,reduce,yield等) map函数 Python实际上提供了一个内置的工具,map函数.这个函数的主要功能是对一个序列对象中的每一个元素应 ...

  2. Python经常使用内置函数介绍【filter,map,reduce,apply,zip】

    Python是一门非常简洁,非常优雅的语言,其非常多内置函数结合起来使用,能够使用非常少的代码来实现非常多复杂的功能,假设相同的功能要让C/C++/Java来实现的话,可能会头大,事实上Python是 ...

  3. python学习笔记(十六)内置函数zip、map、filter的使用

    1.zip,就是把两个或者多个list,合并到一起,如果想同时循环2个list的时候,就使用zip.示例如下: l1 = ['a','b','c','e','f','g'] l2 = [,,] l3= ...

  4. python filter map reduce

    filter(function, iterable): Construct a list from those elements of iterable for which function retu ...

  5. python基础---列表生成器、迭代器等

    一.列表生成式 用来创建list的表达式,相当于for循环的简写形式 语法: [表达式 for循环 判断条件] ''' 普通写法 ''' def test(): l= [] for i in rang ...

  6. (Python)list的内建函数 filter(), map(), 和 reduce()

    这一节,我们将主要学习用于list的三个内建函数: filter(), map(), 和 reduce(). 1.filter(function, sequence)  逐个从sequence中取一个 ...

  7. Python 函数 切片 迭代 列表生成器

    函数 编写     定义一个函数要用def语句    def sum(i,n):   ⚠有冒号 返回多值     实际上是返回一个tuple 定义默认参数    默认参数的作用是简化调用   def ...

  8. Python学习——filter&map

    filter&map 1.filter函数 filter()函数用于过滤序列,过滤掉不符合条件的元素,Python3以后返回一个迭代器对象(可以用list()转化为列表查看). filter( ...

  9. 小学生都能学会的python(<lamda匿名函数,sorted(),filter(),map(),递归函数>)

    小学生都能学会的python(<<lamda匿名函数,sorted(),filter(),map(),递归函数,二分法>> 1. lambda 匿名函数 lambda 参数: ...

随机推荐

  1. vs2010 编译多个project问题

    使用VS2010 编译从vc6.0复制过来的原project文件源代码.提示错误非常多.感觉无从下手.非常多原始的函数和API參数都提示类型 错误或者不兼容. 百度一下.第一个问题: vc6.0使用A ...

  2. 模拟服务器MockServer之Moco详细介绍

    转载:http://blog.csdn.net/vite_s/article/details/54583243 前面一篇介绍了如何用mockito来测试我们的一些异步任务,例如网络请求时候的异步回调. ...

  3. Windows局域网如何进行远程桌面连接

    我们以虚拟机为例: 1 确保被控制的计算机允许远程连接   2 确保被控制的计算机有密码(一般人方便,只有一个administrator账号,而且不设密码,开机直接进入的,如果没有密码,将无法进行远程 ...

  4. 标准库Allocator的使用(一)

    上一篇我们提到了new运算符以及它的工作步骤,其实无非是把两项工作独立出来: 1.申请原始内存 2.执行构造函数 delete也涉及了两个工作: 1.执行析构函数 2.释放原始内存 其实标准库提供了另 ...

  5. cpu、内存、硬盘

    grep -c 'model name' /proc/cpuinfo

  6. Oracle 修改表名

    .ALTER TABLE T_PLAT_KEYWORD_STATISTIC RENAME TO T_PLAT_KEYWORD; .create new_table as select * from o ...

  7. MySQL查询缓存设置提高MySQL查询性能

    首先看看MSYQL逻辑框架:图片来自高性能mysql 如果使用了QueryCache,当查询接收到一个和之前同样的查询,服务器将会从查询缓存中检索结果,而不是再次分析和执行相同的查询.这样就能大大提高 ...

  8. 如何进入到Docker容器内部

    启动Docker容器后,对应的服务(例如tomcat启动)也通过dockerfile文件命令运行起来了,这个时候如何进行容器内部观察容器的运行状态. 1.docker attach 这个命令在创建一个 ...

  9. 阿里巴巴 DevOps 转型后的运维平台建设

    原文:http://www.sohu.com/a/156724220_262549 本文转载自公众号「DevOps 时代」,高效运维社区致力于陪伴您的职业生涯,与您一起愉快的成长. 作者简介: 陈喻( ...

  10. c#关于路径的总结(转) 虚拟路径波浪号~和斜杠/的区别

    c#关于路径的总结(转)   来源:http://www.cnblogs.com/yugongmengjiutian/articles/5521165.html 前一段时间写代码时经常遇到获取路径问题 ...