您好,登錄后才能下訂單哦!
小編給大家分享一下Python如何使字符串作為變量名,相信大部分人都還不怎么了解,因此分享這邊文章給大家學(xué)習(xí),希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去學(xué)習(xí)方法吧!
應(yīng)用場(chǎng)景描述:
通過(guò)配置文件獲取服務(wù)器上配置的服務(wù)名及運(yùn)行端口號(hào),編寫(xiě)python腳本檢測(cè)服務(wù)上服務(wù)是否在運(yùn)行?
#!/usr/bin/env python # -*- coding:utf-8 -*- # fileName: config.py # 服務(wù)配置 class config: serviceList = 'service1,service2,service3' service1 = '服務(wù)1' service1Port = 8001 service2 = '服務(wù)2' service2Port = 8002 service3 = '服務(wù)3' service3Port = 8003
#!/usr/bin/env python # -*- coding:utf-8 -*- # fileName: envCheck.py import socket from config import config config = config serviceList = config.serviceList # 判斷某端口服務(wù)是否運(yùn)行 def portCheck(host, port): sk = socket.socket(socket.AF_INET, socket.SOCK_STREAM) sk.settimeout(1) try: sk.connect((host, port)) # print '在服務(wù)器 %s 上服務(wù)端口 %d 的服務(wù)正在運(yùn)行!' % (host, port) return True except Exception: # print '在服務(wù)器 %s 上服務(wù)端口 %d 的服務(wù)未運(yùn)行!' % (host, port) return False sk.close() # 基礎(chǔ)服務(wù)運(yùn)行狀態(tài)檢測(cè) def envCheck(): for serviceName in serviceList.split(','): host = '127.0.0.1' # 必須為字符串格式,如:'127.0.0.1' servicePort = ''.join(['config.',serviceName,'Port']) port = eval(servicePort) # 端口必須為數(shù)字 if portCheck(host, port): print u"在%s服務(wù)器上服務(wù)端口為 %s 的 %s 服務(wù)正在運(yùn)行......" % (host, port, serviceName) else: print u"在%s服務(wù)器上服務(wù)端口為 %s 的 %s 服務(wù)未運(yùn)行!" % (host, port, serviceName) if __name__ == "__main__": envCheck()
這個(gè)里面使用到了將字符串作為變量名的方式從配置中獲取服務(wù)端口,下面我們具體看下除了這種方式以外還有哪些方式可以實(shí)現(xiàn)。
一共有三種實(shí)現(xiàn)方法:
# 方法一: >> servicePort = ''.join(['config.',serviceName,'Port']) >>port = locals()[servicePort)] >>print "%s:%d" %(serviceName, port) # 輸出結(jié)果 service1Port:8001 service2Port:8002 service3Port:8003 # 方法二: >> servicePort = ''.join(['config.',serviceName,'Port']) >>port = vars()[servicePort)] >>print "%s:%d" %(serviceName, port) # 輸出結(jié)果 service1Port:8001 service2Port:8002 service3Port:8003 # 方法三: >> servicePort = ''.join(['config.',serviceName,'Port']) >>port = eval(servicePort) >>print "%s:%d" %(serviceName, port) # 輸出結(jié)果 service1Port:8001 service2Port:8002 service3Port:8003
1. locals()
locals是python的內(nèi)置函數(shù),他可以以字典的方式去訪問(wèn)局部和全局變量。
python里面用名字空間記錄著變量,就像javascript的window一樣,他記錄著各種全局變量。
每個(gè)模塊,每個(gè)函數(shù)都有自己的名字空間,記錄著變量,常量,類的命名和值。
就像JS一樣,當(dāng)python在使用變量時(shí),會(huì)按照下面的步驟去搜索:
·函數(shù)或類的局部變量。
·全局變量。
·內(nèi)置變量。
以上三個(gè)步驟,其中一步驟找到對(duì)應(yīng)的變量,就不會(huì)再往下找。如果在這三個(gè)步驟都找不到,就會(huì)拋出異常。
locals與globals的區(qū)別
·locals()是只讀的。globals()不是。這里說(shuō)的只讀,是值對(duì)于原有變量的只讀。其實(shí)還可以對(duì)locals()賦值的。
·globals返回的是當(dāng)前模塊的全局變量 locals返回的是局部變量。注意,locals返回的是當(dāng)前所在最小命名空間的局部變量的一個(gè)拷貝。
體檢locals
list1 = [1,2,3] locals() # 在全局中使用locals,會(huì)打印出list1和__builtins__、__name__、__doc__、__package__ def foo(args): x=1 print locals() foo(123) #將會(huì)得到 {'arg':123,'x':1}
2. vars()
本函數(shù)是實(shí)現(xiàn)返回對(duì)象object的屬性和屬性值的字典對(duì)象。如果默認(rèn)不輸入?yún)?shù),就打印當(dāng)前調(diào)用位置的屬性和屬性值,相當(dāng)于locals()的功能。如果有參數(shù)輸入,就只打印這個(gè)參數(shù)相應(yīng)的屬性和屬性值。
#vars() print(vars()) class Foo: a = 1 print(vars(Foo)) foo = Foo() print(vars(foo))
3. eval()
eval()函數(shù)十分強(qiáng)大,官方demo解釋為:將字符串str當(dāng)成有效的表達(dá)式來(lái)求值并返回計(jì)算結(jié)果。
結(jié)合math當(dāng)成一個(gè)計(jì)算器很好用。
其他用法,可以把list,tuple,dict和string相互轉(zhuǎn)化。見(jiàn)下例子:
a = "[[1,2], [3,4], [5,6], [7,8], [9,0]]" b = eval(a) b Out[3]: [[1, 2], [3, 4], [5, 6], [7, 8], [9, 0]] type(b) Out[4]: list a = "{1: 'a', 2: 'b'}" b = eval(a) b Out[7]: {1: 'a', 2: 'b'} type(b) Out[8]: dict a = "([1,2], [3,4], [5,6], [7,8], (9,0))" b = eval(a) b Out[11]: ([1, 2], [3, 4], [5, 6], [7, 8], (9, 0))
強(qiáng)大的函數(shù)有代價(jià)。安全性是其最大的缺點(diǎn)。
想一想這種使用環(huán)境:需要用戶輸入一個(gè)表達(dá)式,并求值。
如果用戶惡意輸入,例如:
__ import__('os').system('dir')
那么eval()之后,你會(huì)發(fā)現(xiàn),當(dāng)前目錄文件都會(huì)展現(xiàn)在用戶前面。
那么繼續(xù)輸入:
open('文件名').read()
代碼都給人看了。獲取完畢,一條刪除命令,文件消失??薨桑?/p>
怎么避免安全問(wèn)題?
(1)自行寫(xiě)檢查函數(shù);
(2)使用ast.literal_eval
以上是Python如何使字符串作為變量名的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。