我在使用 ast.literal_eval() 时遇到问题。在下面的示例中,我只想将字符串 (myText) 转换为字典。但 ast.literal_eval() 尝试评估<__main__.myClass instance at 0x0000000052D64D88>
并给我一个错误。我完全理解这个错误,但我想知道是否有办法避免它(使用其他函数或使用其他方法来使用函数 ast.literal_eval)
import ast
myText = "{<__main__.myClass instance at 0x0000000052D64D88>: value}"
ast.literal_eval(myText)
# Error: invalid syntax
# Traceback (most recent call last):
# File "<maya console>", line 4, in <module>
# File "C:\Program Files\Autodesk\Maya2016\bin\python27.zip\ast.py", line 49, in literal_eval
# node_or_string = parse(node_or_string, mode='eval')
# File "C:\Program Files\Autodesk\Maya2016\bin\python27.zip\ast.py", line 37, in parse
# return compile(source, filename, mode, PyCF_ONLY_AST)
# File "<unknown>", line 1
# {<__main__.myClass instance at 0x0000000052D64D88>: value}
# ^
# SyntaxError: invalid syntax #
预先感谢您的帮助 !
你真正想做的是使用转储你的数据pickle.dump
并使用加载它pickle.load
(或等效的,例如 json 等)。使用repr(data)
转储数据会导致这样的问题。
如果您只需要挽救已经生成的数据,那么您might摆脱类似以下的事情:
def my_literal_eval(s):
s = re.sub(r"<__main__.myClass instance at 0x([^>]+)>", r'"<\1>"', s)
dct = ast.literal_eval(s)
return {myClass(): v for v in dct.itervalues()}
使用示例:
>>> import ast, re
>>> class myClass(object): pass
...
>>> myText = "{<__main__.myClass instance at 0x0000000052D64D88>: {'name': 'theName'}, <__main__.myClass instance at 0x0000000052D73F48>: {'name': 'theName'}}"
>>> my_literal_eval(myText)
{<__main__.myClass object at 0x7fbdc00a4b90>: {'name': 'theName'}, <__main__.myClass object at 0x7fbdc0035550>: {'name': 'theName'}}
这仅在以下情况下才有效myClass
实例没有任何有用的信息,仅用于身份识别。这个想法是首先通过替换来修复字符串<__main__.myClass instance ...>
带有可以解析的字符串ast.literal_eval
,然后将其替换为实际的myClass
实例 - 前提是这些实例可以在没有参数的情况下构造,这取决于上述假设。
如果这个最初的假设不成立,那么你的数据就是,正如伊格纳西奥put it,不可逆地损坏,并且任何巧妙的解析都无法找回丢失的位。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)