亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Python functools模塊學習總結

系統 1535 0

文檔 地址

functools.partial

作用:

functools.partial 通過包裝手法,允許我們 "重新定義" 函數簽名

用一些默認參數包裝一個可調用對象,返回結果是可調用對象,并且可以像原始對象一樣對待

凍結部分函數位置函數或關鍵字參數,簡化函數,更少更靈活的函數參數調用

復制代碼 代碼如下:

#args/keywords 調用partial時參數
def partial(func, *args, **keywords):
??? def newfunc(*fargs, **fkeywords):
??????? newkeywords = keywords.copy()
??????? newkeywords.update(fkeywords)
??????? return func(*(args + fargs), **newkeywords) #合并,調用原始函數,此時用了partial的參數
??? newfunc.func = func
??? newfunc.args = args
??? newfunc.keywords = keywords
??? return newfunc

聲明:
復制代碼 代碼如下:

urlunquote = functools.partial(urlunquote, encoding='latin1')

當調用 urlunquote(args, *kargs)

相當于 urlunquote(args, *kargs, encoding='latin1')

E.g:

復制代碼 代碼如下:

import functools

def add(a, b):
??? return a + b

add(4, 2)
6

plus3 = functools.partial(add, 3)
plus5 = functools.partial(add, 5)

plus3(4)
7
plus3(7)
10

plus5(10)
15

應用:

典型的,函數在執行時,要帶上所有必要的參數進行調用。

然后,有時參數可以在函數被調用之前提前獲知。

這種情況下,一個函數有一個或多個參數預先就能用上,以便函數能用更少的參數進行調用。

functool.update_wrapper

默認partial對象沒有__name__和__doc__, 這種情況下,對于裝飾器函數非常難以debug.使用update_wrapper(),從原始對象拷貝或加入現有partial對象

它可以把被封裝函數的__name__、module、__doc__和 __dict__都復制到封裝函數去(模塊級別常量WRAPPER_ASSIGNMENTS, WRAPPER_UPDATES)

復制代碼 代碼如下:

>>> functools.WRAPPER_ASSIGNMENTS
('__module__', '__name__', '__doc__')
>>> functools.WRAPPER_UPDATES
('__dict__',)

這個函數主要用在裝飾器函數中,裝飾器返回函數反射得到的是包裝函數的函數定義而不是原始函數定義

復制代碼 代碼如下:

#!/usr/bin/env python
# encoding: utf-8

def wrap(func):
??? def call_it(*args, **kwargs):
??????? """wrap func: call_it"""
??????? print 'before call'
??????? return func(*args, **kwargs)
??? return call_it

@wrap
def hello():
??? """say hello"""
??? print 'hello world'

from functools import update_wrapper
def wrap2(func):
??? def call_it(*args, **kwargs):
??????? """wrap func: call_it2"""
??????? print 'before call'
??????? return func(*args, **kwargs)
??? return update_wrapper(call_it, func)

@wrap2
def hello2():
??? """test hello"""
??? print 'hello world2'

if __name__ == '__main__':
??? hello()
??? print hello.__name__
??? print hello.__doc__

??? print
??? hello2()
??? print hello2.__name__
??? print hello2.__doc__

得到結果:

復制代碼 代碼如下:

before call
hello world
call_it
wrap func: call_it

before call
hello world2
hello2
test hello

functool.wraps

調用函數裝飾器partial(update_wrapper, wrapped=wrapped, assigned=assigned, updated=updated)的簡寫

復制代碼 代碼如下:

from functools import wraps
def wrap3(func):
??? @wraps(func)
??? def call_it(*args, **kwargs):
??????? """wrap func: call_it2"""
??????? print 'before call'
??????? return func(*args, **kwargs)
??? return call_it

@wrap3
def hello3():
??? """test hello 3"""
??? print 'hello world3'


結果
復制代碼 代碼如下:

before call
hello world3
hello3
test hello 3

functools.reduce

復制代碼 代碼如下:

functools.reduce(function, iterable[, initializer])

等同于內置函數reduce()

用這個的原因是使代碼更兼容(python3)

functools.cmp_to_key

functools.cmp_to_key(func)
將老式鼻尖函數轉換成key函數,用在接受key函數的方法中(such as sorted(), min(), max(), heapq.nlargest(), heapq.nsmallest(), itertools.groupby())

一個比較函數,接收兩個參數,小于,返回負數,等于,返回0,大于返回整數

key函數,接收一個參數,返回一個表明該參數在期望序列中的位置

例如:

復制代碼 代碼如下:

sorted(iterable, key=cmp_to_key(locale.strcoll))? # locale-aware sort order

functools.total_ordering

復制代碼 代碼如下:

functools.total_ordering(cls)

這個裝飾器是在python2.7的時候加上的,它是針對某個類如果定義了__lt__、le、gt、__ge__這些方法中的至少一個,使用該裝飾器,則會自動的把其他幾個比較函數也實現在該類中
復制代碼 代碼如下:

@total_ordering
class Student:
??? def __eq__(self, other):
??????? return ((self.lastname.lower(), self.firstname.lower()) ==
??????????????? (other.lastname.lower(), other.firstname.lower()))
??? def __lt__(self, other):
??????? return ((self.lastname.lower(), self.firstname.lower()) <
??????????????? (other.lastname.lower(), other.firstname.lower()))
print dir(Student)

得到
復制代碼 代碼如下:

['__doc__', '__eq__', '__ge__', '__gt__', '__le__', '__lt__', '__module__']


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 亚洲精品久久玖玖玖玖 | 一个色综合网 | 欧美色视频网 | 国产日韩欧美亚洲综合首页 | 午夜在线观看免费影院 | 亚洲国产人成在线观看69网站 | 在线成人中文字幕 | 久久精品视频大全 | 精品久久久久久国产91 | 女人十八毛片免费特黄 | 免费福利视频在线观看 | 日本一区二区三区四区公司 | 思99re久久这里只有精品首页 | 爱爱免费视频网站 | 亚洲另类在线视频 | 亚洲欧洲日韩在线 | 全免费午夜一级毛片真人 | 老妇色| 亚洲国产成人久久综合野外 | 亚洲国产成人久久一区二区三区 | 人人看人人鲁狠狠高清 | 久久九九有精品国产56 | 四虎海外在线永久免费看 | 日本一级特黄毛片免费视频 | 久久免费99精品久久久久久 | 久久经典 | 伊人久久中文字幕久久cm | 亚洲国产成人精品一区91 | 成人国产精品999视频 | 色狠狠一区 | 亚洲国产精品免费视频 | 亚洲精品图 | 国产精品成aⅴ人片在线观看 | 日韩欧美毛片免费观看视频 | 国产亚洲午夜精品a一区二区 | 兔子bt资源在线 | 全黄一级裸片视频在线观看 | 亚洲高清视频网站 | 国产一国产一级毛片视频 | 日本一级毛片视频 | 99久久99这里只有免费费精品 |