python動態(tài)加載變量示例分享
眾所周知,程序在啟動后,各個(gè)程序文件都會被加載到內(nèi)存中,這樣如果程序文本再次變化,對當(dāng)前程序的運(yùn)行沒有影響,這對程序是一種保護(hù)。
但是,對于像python這樣解釋執(zhí)行的語言,我們有時(shí)候會用到“from 模塊 import 變量名”這樣的形式,如果這個(gè)變量直接被定義在文件當(dāng)中,那么這些變量在程序開始時(shí)就會被定義、賦值,運(yùn)行過程中值不變。如果打算在運(yùn)行過程中對這個(gè)模塊進(jìn)行重寫,那么更改后的變量值是無法被使用的。
對于這個(gè)問題,可以換一種思路,將這個(gè)模塊中的變量定義在函數(shù)里,而函數(shù)是在程序運(yùn)行的時(shí)候動態(tài)執(zhí)行的,這樣就能夠獲取到變量的最新值。下面是例子:
首先,不使用函數(shù)的情況:
#model1.py
p_hello = 'hello world!'
#test1.py
from model1 import p_hello
file = open('model1.py', 'w')
file.write("p_hello = '%s!'"%('hello you'))
file.close()
print p_hello
這樣,執(zhí)行test1.py的時(shí)候,出現(xiàn)的結(jié)果仍然是'hello world',而非‘hello you',說明變量已經(jīng)加載到內(nèi)存中,盡管該模塊的文件在硬盤上已經(jīng)被重寫。
接下來,使用函數(shù)的情況:
#model1.py
def rule():
p_hello = 'hello world!'
return locals()
#test1.py
from model1 import rule
file = open('model1.py', 'w')
file.write('def rule():\n')
file.write(" p_hello = '%s!'\n"%('hello you'))
file.write(" return locals()\n")
file.close()
p_hello = rule()['p_hello']
print p_hello
這樣,print出來的結(jié)果就是hello you 了,因?yàn)樵谶\(yùn)行的時(shí)候,先執(zhí)行了一遍這個(gè)函數(shù),再通過函數(shù)獲取了這個(gè)變量,這樣就會獲得新值。
相關(guān)文章
Python實(shí)現(xiàn)PS濾鏡中馬賽克效果示例
這篇文章主要介紹了Python實(shí)現(xiàn)PS濾鏡中馬賽克效果,涉及Python基于skimage庫的圖形馬賽克效果相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-01-01分析Python中解析構(gòu)建數(shù)據(jù)知識
本篇文章給大家講述一下Python中解析構(gòu)建數(shù)據(jù)知識的相關(guān)內(nèi)容,有需要的朋友跟著學(xué)習(xí)下。2018-01-01加速Python代碼執(zhí)行利器使用實(shí)例探究
這篇文章主要為大家介紹了加速Python代碼執(zhí)行的利器使用實(shí)例探究,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-01-01封裝Detours用于Python中x64函數(shù)hook詳解
Detours是微軟發(fā)布的一個(gè)API hook框架,同時(shí)支持x86和x64,看文檔說也支持ARM和ARM64的Windows,這篇文章主要介紹了封裝Detours用于Python中x64函數(shù)hook,需要的朋友可以參考下2023-12-12