方法一:直接調(diào)用函數(shù)運(yùn)行
這種是最簡(jiǎn)單且直觀(guān)的方法
deftask():
print("runningtask")
task()
如果是在類(lèi)中,也是如此
classTask:
deftask(self):
print("runningtask")
Task().task()
方法二:使用偏函數(shù)來(lái)執(zhí)行
在 functools 這個(gè)內(nèi)置庫(kù)中,有一個(gè) partial 方法專(zhuān)門(mén)用來(lái)生成偏函數(shù)。
defpower(x,n):
s=1
whilen>0:
n=n-1
s=s*x
returns
fromfunctoolsimportpartial
power_2=partial(power,n=2)
power_2(2)#output:4
power_2(3)#output:9
方法三:使用 eval 動(dòng)態(tài)執(zhí)行
如果你有需要?jiǎng)討B(tài)執(zhí)行函數(shù)的需要,可以使用 eval + 字符串 來(lái)執(zhí)行函數(shù)。
importsys
defpre_task():
print("runningpre_task")
deftask():
print("runningtask")
defpost_task():
print("runningpost_task")
argvs=sys.argv[1:]
foractioninargvs:
eval(action)()
運(yùn)行效果如下
$pythondemo.pypre_tasktaskpost_task
runningpre_task
runningtask
runningpost_task
方法四:使用 getattr 動(dòng)態(tài)獲取執(zhí)行
若把所有的函數(shù)是放在類(lèi)中,并定義成靜態(tài)方法,那就不需要用 eval 了,接著使用 getattr 去獲取并調(diào)用。
importsys
classTask:
@staticmethod
defpre_task():
print("runningpre_task")
@staticmethod
deftask():
print("runningtask")
@staticmethod
defpost_task():
print("runningpost_task")
argvs=sys.argv[1:]
task=Task()
foractioninargvs:
func=getattr(task,action)
func()
方法五:使用類(lèi)本身的字典
我們都知道對(duì)象都有一個(gè)__dict__()的魔法方法,存放所有對(duì)象的屬性及方法。
到這里,大家可以思考一下, 如果還是上面的代碼,我直接取實(shí)例的__dict__()能不能取到函數(shù)呢?
我相信很多人都會(huì)答錯(cuò)。
上面我們定義的是靜態(tài)方法,靜態(tài)方法并沒(méi)有與實(shí)例進(jìn)行綁定,因此靜態(tài)方法是屬于類(lèi)的,但是不是屬于實(shí)例的,實(shí)例雖然有使用權(quán)(可以調(diào)用),但是并沒(méi)有擁有權(quán)。
因此要想通過(guò)__dict__獲取函數(shù),得通過(guò)類(lèi)本身Task,取出來(lái)的函數(shù),調(diào)用方法和平時(shí)的也不一樣,必須先用__func__獲取才能調(diào)用。
importsys
classTask:
@staticmethod
defpre_task():
print("runningpre_task")
func=Task.__dict__.get("pre_task")
func.__func__()
方法六:使用 global() 獲取執(zhí)行
上面放入類(lèi)中,只是為了方便使用getattr的方法,其實(shí)不放入類(lèi)中,也是可以的。此時(shí)你需要借助 globals() 或者 locals() ,它們本質(zhì)上就是一個(gè)字典,你可以直接 get 來(lái)獲得函數(shù)。
importsys
defpre_task():
print("runningpre_task")
deftask():
print("runningtask")
defpost_task():
print("runningpost_task")
argvs=sys.argv[1:]
foractioninargvs:
globals().get(action)()
方法七:從文本中編譯運(yùn)行
先定義一個(gè)字符串,內(nèi)容是你函數(shù)的內(nèi)容,比如上面的 pre_task ,再通過(guò)compile函數(shù)編進(jìn) 編譯,轉(zhuǎn)化為字節(jié)代碼,最后再使用exec去執(zhí)行它。
pre_task="""
print("runningpre_task")
"""
exec(compile(pre_task,'','exec'))
若你的代碼是放在一個(gè) txt 文本中,雖然無(wú)法直接導(dǎo)入運(yùn)行,但仍然可以通過(guò) open 來(lái)讀取,最后使用 compile 函數(shù)編譯運(yùn)行。
withopen('source.txt')asf:
source=f.read()
exec(compile(source,'source.txt','exec'))
方法八:使用 attrgetter 獲取執(zhí)行
在 operator 這個(gè)內(nèi)置庫(kù)中,有一個(gè)獲取屬性的方法,叫attrgetter,獲取到函數(shù)后再執(zhí)行。
fromoperatorimportattrgetter
classPeople:
defspeak(self,dest):
print("Hello,%s"%dest)
p=People()
caller=attrgetter("speak")
caller(p)("明哥")
方法九:使用 methodcaller 執(zhí)行
同樣還是 operator 這個(gè)內(nèi)置庫(kù),有一個(gè) methodcaller 方法,使用它,也可以做到動(dòng)態(tài)調(diào)用實(shí)例方法的效果。
fromoperatorimportmethodcaller
classPeople:
defspeak(self,dest):
print("Hello,%s"%dest)
caller=methodcaller("speak","明哥")
p=People()
caller(p)
以上就是函數(shù)執(zhí)行的九種方法,很多方法,大家也都知道,但是也有幾個(gè)方法,幾乎是見(jiàn)不到的,尤其是后面使用 operator 庫(kù)的那兩種方法。
審核編輯:湯梓紅
-
函數(shù)
+關(guān)注
關(guān)注
3文章
4419瀏覽量
67658 -
python
+關(guān)注
關(guān)注
58文章
4879瀏覽量
90155
發(fā)布評(píng)論請(qǐng)先 登錄
在Python中借助NVIDIA CUDA Tile簡(jiǎn)化GPU編程
Termux中調(diào)試圣誕樹(shù)Python代碼
功函數(shù)在芯片制造中的核心作用
printf函數(shù)在hbird SDK中的應(yīng)用
計(jì)算程序執(zhí)行指令數(shù)的函數(shù)實(shí)現(xiàn)
潘多拉開(kāi)發(fā)板在VSCODE無(wú)法執(zhí)行micropython怎么解決?
【Labview技巧合集】16 在labview中嵌入python做的界面
termux如何搭建python游戲
在Python中字符串逆序有幾種方式,代碼是什么
詳解hal_entry入口函數(shù)
linux虛擬環(huán)境中調(diào)用Linux 版matlab編譯的python庫(kù)時(shí)出錯(cuò)
cyw20719B2 SPI接口slave模式下,在執(zhí)行wiced_hal_pspi_slave_rx_data()函數(shù)的同時(shí),SPI的FIFO還能正確接收數(shù)據(jù)嗎?
基礎(chǔ)篇3:掌握Python中的條件語(yǔ)句與循環(huán)
函數(shù)指針的六個(gè)常見(jiàn)應(yīng)用場(chǎng)景
怎么在python中執(zhí)行函數(shù)
評(píng)論