>> li = [ Larry , Curly ] >>> li.pop // 該語句獲取列表的 pop 方..."/>
溫馨提示×

溫馨提示×

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

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

在Python中通過getattr獲取對象引用的方法

發(fā)布時(shí)間:2020-10-12 03:57:27 來源:腳本之家 閱讀:116 作者:HP的博客 欄目:開發(fā)技術(shù)

getattr函數(shù)

(1)使用 getattr 函數(shù),可以得到一個(gè)直到運(yùn)行時(shí)才知道名稱的函數(shù)的引用。

>>> li = ["Larry", "Curly"]
>>> li.pop
<built-in method pop of list object at 0x7fb75c255518>
// 該語句獲取列表的 pop 方法的引用,注意該語句并不是調(diào)用 pop 方法,調(diào)用 pop 方法的應(yīng)該是 li.pop(), 這里指的是方法對象本身。

>>> getattr(li, "pop")
<built-in method pop of list object at 0x7fb75c2556c8>
// 該語句也是返回 pop 方法的引用,但是此時(shí),方法名稱是作為一個(gè)字符串參數(shù)傳遞給 getattr 函數(shù)的, getattr 是一個(gè)有用到令人無法致信的內(nèi)置函數(shù),可以返回任何對象的任何屬性。在這個(gè)例子中,對象是一個(gè) list, 屬性是 pop 方法。

>>> getattr(li, "append")("Moe")
>>> li
['Larry', 'Curly', 'Moe']
// 如果不確信它是多么的有用,試試這個(gè): getattr 的返回值是 方法, 然后你就可以調(diào)用它,就像直接使用 li.append("Moe") 一樣, 但是實(shí)際上你沒有直接調(diào)用函數(shù), 只是以字符串形式指定了函數(shù)名稱。

>>> getattr({}, "clear")
<built-in method clear of dict object at 0x7fb75c273b40>
// getattr 也可以作用于字典。

>>> getattr((), "pop")
Traceback (most recent call last):
 File "<stdin>", line 1, in <module>
AttributeError: 'tuple' object has no attribute 'pop'
// 理論上, getattr 可以作用于元組,但是由于元組沒有方法,所以不管你指定什么屬性名稱 getattr 都會引發(fā)一個(gè)異常。

(2)用于模塊的 getattr : getattr不僅僅適用于內(nèi)置數(shù)據(jù)類型,也可作用于模塊。

// odbchelper.py
def buildConnectionString(params):
  """Build a connection string from a dictionary of parameters. 
  Returns string."""
  return ";".join(["%s=%s" % (k, v) for k, v in params.items()])

if __name__ == "__main__":
  myParams = {"server":"mpilgrim",\
        "database":"master",\
        "uid":"sa",\
        "pwd":"secret"
        }
  print buildConnectionString(myParams)
// end

>>> import odbchelper
>>> odbchelper.buildConnectionString
<function buildConnectionString at 0x7fb75c26e848>
// 該語句返回 odbchelper 模塊中 buildConnectionString 函數(shù)的引用

>>> getattr(odbchelper, "buildConnectionString")
<function buildConnectionString at 0x7fb75c26e848>
// 使用 getattr, 你能夠獲得同一函數(shù)的同一引用, 通常, getattr(object," attribute ")等價(jià)于 object.attribute, 如果 object 是一個(gè)模塊的話,那么 attribute 可能是定義在模塊中的任何東西:函數(shù)、類或者全局變量。

>>> object = odbchelper
>>> method = "buildConnectionString"
>>> getattr(object, method)
<function buildConnectionString at 0x7fb75c26e848>
// object 作為一個(gè)參數(shù)傳遞給函數(shù), method 是方法或者函數(shù)的名稱字符串。

>>> type(getattr(object, method))
<type 'function'>
>>> import types
>>> type(getattr(object, method)) == types.FunctionType
True
// method 是函數(shù)的名稱,通過獲取 type 可以進(jìn)行驗(yàn)證。

>>> callable(getattr(object, method))
True
// 由于 method 是一個(gè)函數(shù), 所以它是可調(diào)用的。

(3)getattr 作為一 個(gè)分發(fā)者

getattr 常見的使用模式是作為一個(gè)分發(fā)者。舉個(gè)例子, 如果你有一個(gè)程序可以以不同的格式輸出數(shù)據(jù),你可以為每種輸出格式定義各自的格式輸出函數(shù), 然后使用唯一的分發(fā)函數(shù)調(diào)用所需的格式輸出函數(shù)。

例如, 我們假設(shè)有一個(gè)以 HTML、XML 和普通文本格式打印站點(diǎn)統(tǒng)計(jì)的程序。輸出格式在命令行中指定, 或者保存在配置文件中, statsout 模塊定義了三個(gè)函數(shù): output_html 、 output_xml 和 output_text , 然后主程序定義了唯一的輸出函數(shù), 如下:

import statsout

def output(data, format="text"):    (1)
  output_function = getattr(statsout, "output_%s" % \
          format, statsout.output_text)   (2)
  return output_function(data)    (3)    

(1) output 函數(shù)接收一個(gè)必備參數(shù) data, 和一個(gè)可選參數(shù) format, 如果沒有指定 format 參數(shù), 其缺省值是 text 并完成普通文本輸出函數(shù)的調(diào)用。

(2) 你可以連接 format 參數(shù)值和 “output_” 來創(chuàng)建一個(gè)函數(shù)名稱作為參數(shù)值, 然后從 statsout 模塊中取得該函數(shù), 第三個(gè)參數(shù)是一個(gè)缺省返回值, 如果第二個(gè)參數(shù)指定的屬性或者方法沒能找到, 則將返回這個(gè)缺省返回值。這種方式允許今后很容易地?cái)U(kuò)展程序以支持其它的輸出格式,而且無需修改分發(fā)函數(shù)。所要做的僅僅是向 statsout 中添加一個(gè)函數(shù),比如 output_pdf, 之后只要將 “pdf” 作為 format 的參數(shù)值傳遞給 output 函數(shù)即可。

(3) 現(xiàn)在你可以簡單地調(diào)用輸出函數(shù),就像調(diào)用其它函數(shù)一樣, output_function 變量是指向 statsout 模塊中相應(yīng)函數(shù)的引用。

以上這篇在Python中通過getattr獲取對象引用的方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

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

AI