以python 3.8.5150.0版本為例,python中eval函數(shù)作用如下:
成都創(chuàng)新互聯(lián)服務項目包括綏濱網(wǎng)站建設、綏濱網(wǎng)站制作、綏濱網(wǎng)頁制作以及綏濱網(wǎng)絡營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,綏濱網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務的客戶以成都為中心已經(jīng)輻射到綏濱省份的部分城市,未來相信會繼續(xù)擴大服務區(qū)域并繼續(xù)獲得客戶的支持與信任!
1、計算字符串中有效的表達式,并返回結(jié)果。
2、將字符串轉(zhuǎn)成相應的對象(如list、tuple、dict和string之間的轉(zhuǎn)換)。
3、將利用反引號轉(zhuǎn)換的字符串再反轉(zhuǎn)回對象。
參數(shù)解析:
expression:這個參數(shù)是一個字符串,python會使用globals字典和locals字典作為全局和局部的命名空間,將expression當作一個python表達式進行解析和計算。
globals:這個參數(shù)控制的是一個全局的命名空間,也就是我們在計算表達式的時候可以使用全局的命名空間中的函數(shù),如果這個參數(shù)被提供了。
并且沒有提供自定義的builtins(python的內(nèi)建模塊),那么會將當前環(huán)境中的builtins拷貝到提供的globals里,然后進行計算。如果globals沒有被提供,則使用python的全局命名空間。
locals:這個參數(shù)控制的是一個局部的命名空間,和globals類似,不過當它和globals中有重復的部分時,locals里的定義會覆蓋掉globals中的,也就是說當globals和locals中有沖突的部分時,locals說了算,它有決定權(quán),以它的為準。如果locals沒有被提供的話,則默認為globals。
lambda是個匿名函數(shù)而已, 這里就是產(chǎn)生了字典{True:f1, False f2},字典的兩個值就是2個函數(shù),f1 就是shutil.copy(...),f2就是copytree了,你可以理解成兩個函數(shù)指針。
bresult是個true或者false的值,后面[bresult]():就表示,根據(jù)bresult的結(jié)果調(diào)用前面字典里面對應的兩個函數(shù)。bresult在這里是字典的key。函數(shù)在這里是字典的value.
剛學用Python的時候,特別是看一些庫的源碼時,經(jīng)常會看到func(*args, **kwargs)這樣的函數(shù)定義,這個*和**讓人有點費解。其實只要把函數(shù)參數(shù)定義搞清楚了,就不難理解了。
先說說函數(shù)定義,我們都知道,下面的代碼定義了一個函數(shù)funcA
def funcA():
pass
顯然,函數(shù)funcA沒有參數(shù)(同時啥也不干:D)。
下面這個函數(shù)funcB就有兩個參數(shù)了,
def funcB(a, b):
print a
print b
調(diào)用的時候,我們需要使用函數(shù)名,加上圓括號擴起來的參數(shù)列表,比如 funcB(100, 99),執(zhí)行結(jié)果是:
100
99
很明顯,參數(shù)的順序和個數(shù)要和函數(shù)定義中一致,如果執(zhí)行funcB(100),Python會報錯的:
TypeError: funcB() takes exactly 2 arguments (1 given)
我們可以在函數(shù)定義中使用參數(shù)默認值,比如
def funcC(a, b=0):
print a
print b
在函數(shù)funcC的定義中,參數(shù)b有默認值,是一個可選參數(shù),如果我們調(diào)用funcC(100),b會自動賦值為0。
OK,目前為止,我們要定義一個函數(shù)的時候,必須要預先定義這個函數(shù)需要多少個參數(shù)(或者說可以接受多少個參數(shù))。一般情況下這是沒問題的,但是也有在定義函數(shù)的時候,不能知道參數(shù)個數(shù)的情況(想一想C語言里的printf函數(shù)),在Python里,帶*的參數(shù)就是用來接受可變數(shù)量參數(shù)的。看一個例子
def funcD(a, b, *c):
print a
print b
print "length of c is: %d " % len(c)
print c
調(diào)用funcD(1, 2, 3, 4, 5, 6)結(jié)果是
1
2
length of c is: 4
(3, 4, 5, 6)
我們看到,前面兩個參數(shù)被a、b接受了,剩下的4個參數(shù),全部被c接受了,c在這里是一個tuple。我們在調(diào)用funcD的時候,至少要傳遞2個參數(shù),2個以上的參數(shù),都放到c里了,如果只有兩個參數(shù),那么c就是一個empty tuple。
好了,一顆星我們弄清楚了,下面輪到兩顆星。
上面的例子里,調(diào)用函數(shù)的時候,傳遞的參數(shù)都是根據(jù)位置來跟函數(shù)定義里的參數(shù)表匹配的,比如funcB(100, 99)和funcB(99, 100)的執(zhí)行結(jié)果是不一樣的。在Python里,還支持一種用關(guān)鍵字參數(shù)(keyword argument)調(diào)用函數(shù)的辦法,也就是在調(diào)用函數(shù)的時候,明確指定參數(shù)值付給那個形參。比如還是上面的funcB(a, b),我們通過這兩種方式調(diào)用
funcB(a=100, b=99)
和
funcB(b=99, a=100)
結(jié)果跟funcB(100, 99)都是一樣的,因為我們在使用關(guān)鍵字參數(shù)調(diào)用的時候,指定了把100賦值給a,99賦值給b。也就是說,關(guān)鍵字參數(shù)可以讓我們在調(diào)用函數(shù)的時候打亂參數(shù)傳遞的順序!
另外,在函數(shù)調(diào)用中,可以混合使用基于位置匹配的參數(shù)和關(guān)鍵字參數(shù),前題是先給出固定位置的參數(shù),比如
def funcE(a, b, c):
print a
print b
print c
調(diào)用funcE(100, 99, 98)和調(diào)用funcE(100, c=98, b=99)的結(jié)果是一樣的。
好了,經(jīng)過以上鋪墊,兩顆星總算可以出場了:
如果一個函數(shù)定義中的最后一個形參有 ** (雙星號)前綴,所有正常形參之外的其他的關(guān)鍵字參數(shù)都將被放置在一個字典中傳遞給函數(shù),比如:
def funcF(a, **b):
print a
for x in b:
print x + ": " + str(b[x])
調(diào)用funcF(100, c='你好', b=200),執(zhí)行結(jié)果
100
c: 你好
b: 200
大家可以看到,b是一個dict對象實例,它接受了關(guān)鍵字參數(shù)b和c。