溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

map filter reduce

發(fā)布時(shí)間:2020-07-17 15:20:21 來源:網(wǎng)絡(luò) 閱讀:427 作者:cooperfang 欄目:編程語言
# map
# map  : what why how
# http://devdocs.io/python~3.6/library/functions#map  官方文檔
# 返回一個(gè)迭代器,該迭代器將函數(shù)應(yīng)用到可迭代的每一項(xiàng),從而產(chǎn)生結(jié)果
# 不用for循環(huán),就能將序列中的數(shù)據(jù)一一映射到給定的處理函數(shù),快速對(duì)一個(gè)序列的數(shù)據(jù)進(jìn)行各種操作
# 是代碼更簡單
map?
"""Init signature: map(self, /, *args, **kwargs)
Docstring:     
map(func, *iterables) --> map object
函數(shù)用--------------------> 返回的map對(duì)象
"""
num = [1,3,5,7,9]
# for 循環(huán)
new_num = []
for i in num:
    y = i + 1
    new_num.append(y)
print(new_num)
[2, 4, 6, 8, 10]
# map
def add(x):
    return(x+1)

map(add, num)
<map at 0x14d150489e8>
list(map(add, num))
[2, 4, 6, 8, 10]
# 字符串處理
str_list = ['lilei', 'coop', 'hanmei']

def change(s:str):
    return s.capitalize()

list(map(change, str_list))
['Lilei', 'Coop', 'Hanmei']
# filter
# 從可迭代的元素中構(gòu)造一個(gè)迭代器,函數(shù)返回true,iterable可以是一個(gè)序列,一個(gè)支持迭代的容器
# 或者一個(gè)迭代器,如果函數(shù)為None,則假定表示函數(shù)為false,即false的所有元素都被刪除
# 不用for循環(huán),就能將序列中數(shù)據(jù)一一映射到給定的處理函數(shù),函數(shù)中添加了真假判斷,True則返回
# 相應(yīng)的數(shù)據(jù),最終得到篩選后的序列,使得代碼更簡單
my_list = [11,22,33,44,55,343,66,77]
new_list = []
for i in my_list:
    if 20 < i < 60:
        new_list.append(i)
print(new_list)
[22, 33, 44, 55]
# filter   首先是構(gòu)造一個(gè)過濾田間的函數(shù),然后才能使用filter
def choose(x):
    if 20 < x < 50:
        return True

def choose1(y):
    return 20< y < 50

filter(choose, my_list)
list(filter(choose, my_list))
[22, 33, 44]
# 字符串處理
str_list = ['lilei','coop','coop2','hanmemei','china']

import re

def coop(s:str):
    return re.search('coop', s)
filter(coop, str_list)
list(filter(coop, str_list))
['coop', 'coop2']
# reduce  處理數(shù)字列表的連乘, 累加
# 將兩個(gè)
from functools import reduce
num = [1,3,5,7,9]

sum = 0
for i in num:
    sum += i
print(sum)
25
sum = 1
for i in num:
    sum *= i
print(sum)
945
# 定義函數(shù)
def sum(x, y):
    return x + y
def cheng(x, y):
    return x * y
reduce(sum, num)
25
reduce(cheng, num)
945
向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI