假设我有一个文件:
导入示例

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 Grammaraeval.node_handlers映射寄存器的处理程序进行比较,只需删除不需要的任何处理程序例如,可以删除函数定义、调用、循环、二进制操作(binop)和异常处理。

09-04 10:29