新聞中心
在絕大多數(shù)語(yǔ)言中,都有反射機(jī)制的存在。從作用上來(lái)講,反射是為了增加程序的動(dòng)態(tài)描述能力。通俗一些,就是可以讓用戶參與代碼執(zhí)行的決定權(quán)。
在程序編寫(xiě)的時(shí)候,我們會(huì)寫(xiě)很多類(lèi),類(lèi)中又有自己的函數(shù),對(duì)象等等。這些類(lèi)和函數(shù)都是為了后續(xù)代碼服務(wù),程序員決定什么時(shí)候用到哪一個(gè)類(lèi),什么時(shí)候調(diào)用某個(gè)函數(shù)。但很多時(shí)候,我們需要根據(jù)用戶的需求來(lái)決定執(zhí)行哪一段代碼塊。用戶可能是通過(guò)點(diǎn)擊,輸入數(shù)據(jù),或者其他方式發(fā)出指令,反射則將用戶的指令傳遞到需要執(zhí)行的那一段代碼塊。這個(gè)過(guò)程是自動(dòng)執(zhí)行的,無(wú)需人工去核對(duì)用戶指令是否應(yīng)該執(zhí)行那一段代碼,而是由反射機(jī)制自動(dòng)查找該執(zhí)行的代碼塊。大多數(shù)反射都是以web來(lái)進(jìn)行舉例說(shuō)明,而反射本身的最常見(jiàn)的使用場(chǎng)景也確實(shí)是根據(jù)web的url不同來(lái)調(diào)用不同的函數(shù)。當(dāng)然這里,我們不用討論他的具體應(yīng)用,只簡(jiǎn)單說(shuō)明一下他的使用意義。
python的反射機(jī)制設(shè)定較為簡(jiǎn)單,一共有四個(gè)關(guān)鍵函數(shù)分別是getattr、hasattr、setattr、delattr。前兩個(gè)最為常用,最后一個(gè)幾乎很少用到。python本身定義的反射是指在內(nèi)存中對(duì)容器里的某些元素進(jìn)行操作,這個(gè)容器不僅僅包括類(lèi),還包括函數(shù),對(duì)象,這三者不同的是在查找對(duì)象的時(shí)候,除了會(huì)查找對(duì)象自身,還會(huì)去創(chuàng)建對(duì)象的類(lèi)里面進(jìn)行查找。要用實(shí)際例子來(lái)說(shuō)明一下python中的反射具體作用,先看一下需求。所有的語(yǔ)言中,我們都可以輕易辦到讓用戶自由輸入一個(gè)數(shù)據(jù),然后打印那個(gè)數(shù)據(jù),這是最簡(jiǎn)單的人機(jī)交互。在代碼里的實(shí)現(xiàn)過(guò)程是,生成一個(gè)變量,獲取用戶輸入數(shù)據(jù),賦值給變量。打印變量。同理我們可以在某個(gè)類(lèi)中定義兩個(gè)函數(shù),然后要求用戶輸入數(shù)據(jù),根據(jù)用戶輸入的數(shù)據(jù)來(lái)決定具體執(zhí)行哪一個(gè)函數(shù),這就是一個(gè)人工的反射機(jī)制。當(dāng)需要查找的函數(shù)只有兩條的時(shí)候,我們可以用if——else進(jìn)行判斷。但如果數(shù)據(jù)達(dá)數(shù)百條之多,那重復(fù)性使用if不僅效率低下,而且代碼量也難以估量。這種情況,就需要用到反射。
本實(shí)例講述了python中反射用法
import sys, types,new
def _get_mod(modulePath):
try:
aMod = sys.modules[modulePath]
if not isinstance(aMod, types.ModuleType):
raise KeyError
except KeyError:
# The last [''] is very important!
aMod = __import__(modulePath, globals(), locals(), [''])
sys.modules[modulePath] = aMod
return aMod
def _get_func(fullFuncName):
"""Retrieve a function object from a full dotted-package name."""
# Parse out the path, module, and function
lastDot = fullFuncName.rfind(u".")
funcName = fullFuncName[lastDot + 1:]
modPath = fullFuncName[:lastDot]
aMod = _get_mod(modPath)
aFunc = getattr(aMod, funcName)
# Assert that the function is a *callable* attribute.
assert callable(aFunc), u"%s is not callable." % fullFuncName
# Return a reference to the function itself,
# not the results of the function.
return aFunc
def _get_Class(fullClassName, parentClass=None):
"""Load a module and retrieve a class (NOT an instance).
If the parentClass is supplied, className must be of parentClass
or a subclass of parentClass (or None is returned).
"""
aClass = _get_func(fullClassName)
# Assert that the class is a subclass of parentClass.
if parentClass is not None:
if not issubclass(aClass, parentClass):
raise TypeError(u"%s is not a subclass of %s" %
(fullClassName, parentClass))
# Return a reference to the class itself, not an instantiated object.
return aClass
def applyFuc(obj,strFunc,arrArgs):
objFunc = getattr(obj, strFunc)
return apply(objFunc,arrArgs)
def getObject(fullClassName):
clazz = _get_Class(fullClassName)
return clazz()
if __name__=='__main__':
aa=getObject("inetservices.services.company.Company")
bb=applyFuc(aa, "select", ['select * from ngsys2',None])
print bb 網(wǎng)頁(yè)標(biāo)題:創(chuàng)新互聯(lián)Python教程:Python中的反射怎么用?
標(biāo)題鏈接:http://m.fisionsoft.com.cn/article/djehsgo.html


咨詢
建站咨詢
