【Python】map函数

简介: 一 简介    Python 内置了很多非常有用的函数 比如map() ,reduce(),filter(),还有lambda。熟练应用这些函数可以在写python程序的时候构建精简的代码。
一 简介
   Python 内置了很多非常有用的函数 比如map() ,reduce(),filter(),还有lambda。熟练应用这些函数可以在写python程序的时候构建精简的代码。本文先来了解map函数。
二 使用 
用法
  1. map(func, seq1[, seq2,])
map接收两个参数,第一个参数是函数名,第二个是一个或多个可迭代的序列,返回的是一个集合。运行时,map()将func作用于序列中的每一个元素,并将结果作为一个list返回。如果func为None,作用同zip()。
2.1 当seq 只有一个时,map函数返回将func函数作用于 seq每个元素并返回一个新的list集合,

比如需要将seq的元素乘以2 ,使用map可以写成
  1. In [4]: l=[1, 2, 3, 4, 5, 6, 7, 8, 9]
  2. In [5]: map(lambda x:x*2 ,l)
  3. Out[5]: [2, 4, 6, 8, 10, 12, 14, 16, 18]
如果使用函数来做:
  1. rest=[]
  2. for i in l:
  3.   rest.append(i*2)
  4. print rest
map作为高阶函数,能够把运算规则抽象化, 显然map 更精简。

2.2 当有多个seq时,map可以并行的取每个seq对应的第M个元素 seqN[M],进行计算。

例子:
  1. In [9]: map(lambda x , y : x * y, [2,4,6],[3,2,1])
  2. Out[9]: [6, 8, 6]
记得多个seq的元素个数必须一致 不然会报错 
  1. In [1]: print map(lambda x , y : x ** y, [2,4,6],[3,2,1])
  2. [8, 16, 6]
  3. seq1=[2,4,6] ,seq2=[3,2] 元素个数不一致则报错。
  4. In [3]: print map(lambda x , y : x ** y, [2,4,6],[3,2])
  5. ---------------------------------------------------------------------------
  6. TypeError Traceback (most recent call last)
  7. <ipython-input-3-d075c46afd0b> in <module>()
  8. ----> 1 print map(lambda x , y : x ** y, [2,4,6],[3,2])
  9. <ipython-input-3-d075c46afd0b> in <lambda>(x, y)
  10. ----> 1 print map(lambda x , y : x ** y, [2,4,6],[3,2])
  11. TypeError: unsupported operand type(s) for ** or pow(): 'int' and 'NoneType'
  12. In [4]:
2.3 map在多进程中的应用。

  1. #!/usr/bin/env python
  2. # encoding: utf-8
  3. """
  4. author: yangyi@youzan.com
  5. time: 2017/7/16 上午10:42
  6. func: 参考网络上的例子 
  7. """
  8. import urllib2
  9. from multiprocessing.dummy import Pool as ThreadPool
  10. urls = [
  11.         'http://www.python.org',
  12.         'http://www.python.org/about/',
  13.         'http://www.onlamp.com/pub/a/python/2003/04/17/metaclasses.html',
  14.         'http://www.python.org/doc/',
  15.         'http://www.python.org/download/',
  16.         'http://www.python.org/getit/',
  17.         'http://www.python.org/community/',
  18.         'https://wiki.python.org/moin/',
  19.         'http://planet.python.org/',
  20.         'https://wiki.python.org/moin/LocalUserGroups',
  21.         'http://www.python.org/psf/',
  22.         'http://docs.python.org/devguide/',
  23.         'http://www.python.org/community/awards/'
  24.         ]

  25. # Make the Pool of workers
  26. pool = ThreadPool(4)
  27. # Open the urls in their own threads
  28. # and return the results
  29. results = pool.map(urllib2.urlopen, urls)
  30. #close the pool and wait for the work to finish
  31. pool.close()
  32. pool.join()
该例子使用了 multiprocessing . dummy的线程池Pool的方式,利用用map的特性来处理url集合。
参考文档
[1] [Python] Python中的一些特殊函数

目录
相关文章
|
1月前
|
Python
【python从入门到精通】-- 第五战:函数大总结
【python从入门到精通】-- 第五战:函数大总结
63 0
WK
|
19天前
|
Python
Python中format_map()方法
在Python中,`format_map()`方法用于使用字典格式化字符串。它接受一个字典作为参数,用字典中的键值对替换字符串中的占位符。此方法适用于从字典动态获取值的场景,尤其在处理大量替换值时更为清晰和方便。
WK
67 36
|
28天前
|
Python
Python之函数详解
【10月更文挑战第12天】
Python之函数详解
|
29天前
|
存储 数据安全/隐私保护 索引
|
18天前
|
测试技术 数据安全/隐私保护 Python
探索Python中的装饰器:简化和增强你的函数
【10月更文挑战第24天】在Python编程的海洋中,装饰器是那把可以令你的代码更简洁、更强大的魔法棒。它们不仅能够扩展函数的功能,还能保持代码的整洁性。本文将带你深入了解装饰器的概念、实现方式以及如何通过它们来提升你的代码质量。让我们一起揭开装饰器的神秘面纱,学习如何用它们来打造更加优雅和高效的代码。
|
20天前
|
弹性计算 安全 数据处理
Python高手秘籍:列表推导式与Lambda函数的高效应用
列表推导式和Lambda函数是Python中强大的工具。列表推导式允许在一行代码中生成新列表,而Lambda函数则是用于简单操作的匿名函数。通过示例展示了如何使用这些工具进行数据处理和功能实现,包括生成偶数平方、展平二维列表、按长度排序单词等。这些工具在Python编程中具有高度的灵活性和实用性。
|
23天前
|
Python
python的时间操作time-函数介绍
【10月更文挑战第19天】 python模块time的函数使用介绍和使用。
27 4
|
24天前
|
存储 Python
[oeasy]python038_ range函数_大小写字母的起止范围_start_stop
本文介绍了Python中`range`函数的使用方法及其在生成大小写字母序号范围时的应用。通过示例展示了如何利用`range`和`for`循环输出指定范围内的数字,重点讲解了小写和大写字母对应的ASCII码值范围,并解释了`range`函数的参数(start, stop)以及为何不包括stop值的原因。最后,文章留下了关于为何`range`不包含stop值的问题,留待下一次讨论。
18 1
|
30天前
|
索引 Python
Python中的其他内置函数有哪些
【10月更文挑战第12天】Python中的其他内置函数有哪些
15 1
|
1月前
|
数据处理 Python
深入探索:Python中的并发编程新纪元——协程与异步函数解析
深入探索:Python中的并发编程新纪元——协程与异步函数解析
26 3