我用一个简单的打印命令转储了多个 defaultdict,如下所示:

defaultdict(<type 'list'>, {'actual': [20000.0, 19484.0, 19420.0], 'gold': [20000.0, 19484.0, 19464.0]})

是否有一些标准解析器可以用来检索它们?我知道我应该使用泡菜,但是生成这些 defaultdict 的代码非常慢,我想避免重新运行它。

最佳答案

如果您的 defaultdict 的类型始终是 <type 'list'> ,您可以使用以下内容:

from collections import defaultdict

s = """
defaultdict(<type 'list'>, {'actual': [20000.0, 19484.0, 19420.0], 'gold': [20000.0, 19484.0, 19464.0]})
"""
data = eval(s.replace("<type 'list'>", 'list'))

人们会告诉您 eval() 是不安全和邪恶的,但如果有人试图将有害代码注入(inject)您转储的数据中,他们可能同样可以轻松编辑您的源代码。如果您从中获取此数据的文本文件比源代码更易于访问,那么您可能不想使用此方法。

如果您的 defaultdicts 有多种类型,但它们都是内置类型(或易于在 repr 和类型名称之间转换),那么您仍然可以使用此方法进行多次替换,例如:
for rep, typ in ((repr(list), 'list'), (repr(dict), 'dict')):
    s = s.replace(rep, typ)
data = eval(s)

关于python - 解析 defaultdict 字符串,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/11001471/

10-14 23:44