假设我有一个文件:
导入示例
VVV = 2
DictionaryNameB = {
'a' : VVV,
'bb' : 'SomethingB',
'c' : False,
'ccc' : None,
'dddd' : 'true',
'eeeee' : 0.123456,
'f' : 2,
'h' : [1,2,3]
}
我编写了一个使用
example.py
的函数: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
我得到错误raise valueerror('malformed string');valueerror:malformed string
我知道
ast.literal_eval()
无法解码变量ast.literal_eval()
,有其他方法吗? 最佳答案
您可以使用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
)和异常处理。