【Python】map函式
一 簡介
Python 內建了很多非常有用的函式 比如map() ,reduce(),filter(),還有lambda。熟練應用這些函式可以在寫python程式的時候構建精簡的程式碼。本文先來了解map函式。
二 使用
用法
map接收兩個引數,第一個引數是函式名,第二個是一個或多個可迭代的序列,返回的是一個集合。執行時,map()將func作用於序列中的每一個元素,並將結果作為一個list返回。如果func為None,作用同zip()。
2.1 當seq 只有一個時,map函式返回將func函式作用於 seq每個元素並返回一個新的list集合,
比如需要將seq的元素乘以2 ,使用map可以寫成
如果使用函式來做:
map作為高階函式,能夠把運算規則抽象化,顯然map 更精簡。
2.2 當有多個seq時,map可以並行的取每個seq對應的第M個元素 seqN[M],進行計算。
例子:
記得多個seq的元素個數必須一致 不然會報錯
2.3 map在多程式中的應用。
該例子使用了multiprocessing.dummy的執行緒池Pool的方式,利用用map的特性來處理url集合。
參考文件
[1] [Python] Python中的一些特殊函式
Python 內建了很多非常有用的函式 比如map() ,reduce(),filter(),還有lambda。熟練應用這些函式可以在寫python程式的時候構建精簡的程式碼。本文先來了解map函式。
二 使用
用法
- map(func, seq1[, seq2,…])
2.1 當seq 只有一個時,map函式返回將func函式作用於 seq每個元素並返回一個新的list集合,
比如需要將seq的元素乘以2 ,使用map可以寫成
-
In [4]: l=[1, 2, 3, 4, 5, 6, 7, 8, 9]
-
In [5]: map(lambda x:x*2 ,l)
- Out[5]: [2, 4, 6, 8, 10, 12, 14, 16, 18]
-
rest=[]
-
for i in l:
-
rest.append(i*2)
- print rest
2.2 當有多個seq時,map可以並行的取每個seq對應的第M個元素 seqN[M],進行計算。
例子:
-
In [9]: map(lambda x , y : x * y, [2,4,6],[3,2,1])
- Out[9]: [6, 8, 6]
-
In [1]: print map(lambda x , y : x ** y, [2,4,6],[3,2,1])
-
[8, 16, 6]
-
seq1=[2,4,6] ,seq2=[3,2] 元素個數不一致則報錯。
-
In [3]: print map(lambda x , y : x ** y, [2,4,6],[3,2])
-
---------------------------------------------------------------------------
-
TypeError Traceback (most recent call last)
-
<ipython-input-3-d075c46afd0b> in <module>()
-
----> 1 print map(lambda x , y : x ** y, [2,4,6],[3,2])
-
<ipython-input-3-d075c46afd0b> in <lambda>(x, y)
-
----> 1 print map(lambda x , y : x ** y, [2,4,6],[3,2])
-
TypeError: unsupported operand type(s) for ** or pow(): 'int' and 'NoneType'
- In [4]:
-
#!/usr/bin/env python
-
# encoding: utf-8
-
"""
-
author: yangyi@youzan.com
-
time: 2017/7/16 上午10:42
-
func: 參考網路上的例子
-
"""
-
import urllib2
-
from multiprocessing.dummy import Pool as ThreadPool
-
urls = [
-
'',
-
'/about/',
-
'',
-
'/doc/',
-
'/download/',
-
'/getit/',
-
'/community/',
-
'',
-
'',
-
'LocalUserGroups',
-
'/psf/',
-
'http://docs.python.org/devguide/',
- '/community/awards/'
-
]
-
-
# Make the Pool of workers
-
pool = ThreadPool(4)
-
# Open the urls in their own threads
-
# and return the results
-
results = pool.map(urllib2.urlopen, urls)
-
#close the pool and wait for the work to finish
-
pool.close()
- pool.join()
參考文件
[1] [Python] Python中的一些特殊函式
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/22664653/viewspace-2142123/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- python_map()函式Python函式
- python中id()函式、zip()函式、map()函式、lamda函式Python函式
- 【Python】python map()函式和lambda表示式Python函式
- python內建函式 map/reducePython函式
- Python 擴充之特殊函式(lambda 函式,map 函式,filter 函式,reduce 函式)Python函式Filter
- Python 中的map、reduce函式用法Python函式
- python之高階函式map,reduce,filter用法Python函式Filter
- python基礎 python內建函式map/reduce/filterPython函式Filter
- map 和 lambda 函式函式
- lambda匿名函式sorted排序函式filter過濾函式map對映函式函式排序Filter
- python常用函式進階(2)之map,filter,reduce,zipPython函式Filter
- jquery的$.each()函式和$.map()函式的區別jQuery函式
- javascript生成map物件的函式JavaScript物件函式
- 更好用的map函式 flatMap函式
- PHP陣列函式-array_mapPHP陣列函式
- 一個map函式引發的血案函式
- JavaScript(1)高階函式filter、map、reduceJavaScript函式Filter
- javascript高階函式---filter---map---reduceJavaScript函式Filter
- Swift集合函式:Reduce、Map、FlatMap、FilterSwift函式Filter
- Python3之三個內建高階函式map、filter、sortedPython函式Filter
- 用Map+函式式介面來實現策略模式函式模式
- 初級Python中map函式的運用以及列表轉字串的方法Python函式字串
- 理解Swift高階函式之map, filter, reduceSwift函式Filter
- Swift實現多執行緒map函式Swift執行緒函式
- Python strip函式和split函式Python函式
- Python 函式Python函式
- Python函式Python函式
- Python函式與lambda 表示式(匿名函式)Python函式
- 小甲魚python學習總結之函式——lambda fillter() map() 閉包 遞迴Python函式遞迴
- go 1.9 多執行緒安全MAP 函式模組Go執行緒函式
- Python函數語言程式設計-map/reducePython函數程式設計
- Python 函式進階-遞迴函式Python函式遞迴
- Python 函式進階-高階函式Python函式
- python函式每日一講 - int()函式Python函式
- python函式每日一講 - int()函式Python函式
- python函式每日一講 - eval函式Python函式
- Python私有函式和公開函式Python函式
- python函式每日一講 - id函式Python函式