python中的exec()、eval()以及complie()

1.eval函數

函數的作用:

計算指定表達式的值。也就是說它要執行的python代碼只能是單個表達式(注意eval不支持任何形式的賦值操作),而不能是複雜的代碼邏輯。

eval(source, globals=None, locals=None, /)

參數說明:

  • source:必選參數,可以是字符串,也可以是一個任意的code(代碼)對象實例(可以通過complie函數創建)。如果它是一個字符串,它會被當作一個(使用globals和locals參數作爲全局和本地命名空間的)python表達式進行分析和解釋。

  • globals:可選參數,表示全局命名空間(存放全局變量),如果被提供,則必須是一個字典對象。

  • locals:可選參數,表示全局命名空間(存放局部變量),如果被提供,可以是任何映射對象。如果參數被忽略,那麼它將會取與globals相同的值。

如果globals與locals都被忽略,那麼它們將取eval()函數被調用環境下的全局命名空間和局部命名空間。

返回值:

如果source是一個code對象,且創建該code對象時,complie函數的mode參數是‘exec’,那麼eval()函數的返回值是None;

  • 否則,如果source是一個輸出語句,如print(),則eval()返回結果爲None;

  • 否則,source表達式的結果就是eval()函數的返回值

實例:

x = 10
def func():
    y = 20   #局部變量y
    a = eval("x+y")
    print("a:",a)      #x沒有就調用全局變量
    b = eval("x+y",{"x":1,"y":2})     #定義局部變量,優先調用
    print("b:",b)
    c = eval("x+y",{"x":1,"y":2},{"y":3,"z":4})  
    print("c:",c)  
    d = eval("print(x,y)")
    print("d:",d)   #對於變量d,因爲print()函數不是一個計算表達式,因此沒有返回值
func()

輸出結果:

a: 30
b: 3
c: 4
10 20
d: None

2.exec函數

函數的作用:

動態執行python代碼。也就是說exec可以執行復雜的python代碼,而不像eval函數那樣只能計算一個表達式的值。

exec(source, globals=None, locals=None, /)

source:必選參數,表示需要被指定的python代碼。它必須是字符串或code對象。如果source是一個字符串,該字符串會先被解析爲一組python語句,然後執行。如果source是一個code對象,那麼它只是被簡單的執行。

返回值:

  • exec函數的返回值永遠爲None。

eval()函數和exec()函數的區別:

  • eval()函數只能計算單個表達式的值,而exec()函數可以動態運行代碼段。

  • eval()函數可以有返回值,而exec()函數返回值永遠爲None。

例1:

我們把eval中的例子拿過來執行

x = 10
def func():
    y = 20
    a = exec("x+y")
    print("a:",a)
    b = exec("x+y",{"x":1,"y":2})
    print("b:",b)
    c = exec("x+y",{"x":1,"y":2},{"y":3,"z":4})
    print("c:",c)
    d = exec("print(x,y)")
    print("d:",d)
func()

執行結果:

#exec不會有任何返回值
a: None   
b: None
c: None
10 20
d: None

例2

x = 10
expr = """
z = 30
sum = x + y + z   #一大包代碼
print(sum)
"""
def func():
    y = 20
    exec(expr)   10+20+30
    exec(expr,{'x':1,'y':2}) 30+1+2
    exec(expr,{'x':1,'y':2},{'y':3,'z':4}) #30+1+3,x是定義全局變量1,y是局部變量

func()

執行結果:

60
33
34

3.complie函數

函數的作用:

compile(source, filename, mode, flags=0, dont_inherit=False, optimize=-1)

參數說明:

  • source:字符串或AST對象,表示需要進行編譯的python代碼

  • filename:指定需要編譯的代碼文件,如果不是文件讀取代碼則傳遞一些可辨認的值。

  • mode:用於標識必須當做那類代表來編譯;如果source是由一個代碼語句序列組成,則指定mode=‘exec’,如果source由單個表達式組成,則指定mode=‘eval’;如果source是由一個單獨的交互式語句組成,則指定modo=‘single’。必須要制定,不然肯定會報錯。

例子:

s = """              #一大段代碼
for x in range(10):
    print(x, end='')  
print()
"""
code_exec = compile(s, '<string>', 'exec')   #必須要指定mode,指定錯了和不指定就會報錯。
code_eval = compile('10 + 20', '<string>', 'eval')   #單個表達式
code_single = compile('name = input("Input Your Name: ")', '<string>', 'single')   #交互式

a = exec(code_exec)   #使用的exec,因此沒有返回值
b = eval(code_eval)  

c = exec(code_single)  #交互
d = eval(code_single)
#Python小白學習交流羣:711312441
print('a: ', a)
print('b: ', b)
print('c: ', c)
print('name: ', name)
print('d: ', d)
print('name; ', name)

執行結果:

0123456789  #有print就會打印
Input Your Name: kebi
Input Your Name: kebi
a:  None
b:  30
c:  None
name:  kebi
d:  None
name;  kebi
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章