假设我有一个文件example.py
:
导入示例
VVV = 2
DictionaryNameB = {
'a' : VVV,
'bb' : 'SomethingB',
'c' : False,
'ccc' : None,
'dddd' : 'true',
'eeeee' : 0.123456,
'f' : 2,
'h' : [1,2,3]
}
我写了一个使用ast.literal_eval()
的函数:
def getDicFromFile(self, dic_name):
with open( 'example.py' ) as f:
file_data = f.read()
match = re.findall('%s[^{]+\{[^\}]+\}' % dic_name, file_data, re.MULTILINE)[0]
# print(match)
dicObject = ast.literal_eval(match[len(dic_name)+3:])
return dicObject
我收到错误引发ValueError('格式错误的字符串'); ValueError:格式错误的字符串
我了解ast.literal_eval()
无法对变量VVV
进行解码,还有其他方法吗?
答案 0 :(得分:6)
您可以使用asteval
,一个基于ast
解析树构建的库来执行有限的语句。它会立即处理你的例子:
from asteval import Interpreter
aeval = Interpreter()
aeval(file_data)
dicObject = aeval.symtable['DictionaryNameB']
或者,您可以导入文件:
from importlib import import_module
module = import_module('example')
dicObject = module.DictionaryNameB
asteval
允许相当多的Python构造。您可以将Python Abstract Grammar与aeval.node_handlers
映射寄存器的处理程序进行比较,然后只删除不需要的任何处理程序。例如,您可以删除函数定义和调用,循环,二进制操作(binop
)和异常处理。