Python使用ast.literal_eval评估包含Python文字的字符串
示例
如果您的字符串包含Python文字,例如字符串,浮点数等,则可以使用ast.literal_eval代替来评估其值eval。这具有仅允许某些语法的附加功能。
>>> import ast >>> code = """(1, 2, {'foo': 'bar'})""" >>> object = ast.literal_eval(code) >>> object (1, 2, {'foo': 'bar'}) >>> type(object) <class 'tuple'>
但是,这对于执行不受信任的用户提供的代码并不安全,并且使用精心设计的输入使解释器崩溃很简单。
>>> import ast >>> ast.literal_eval('()' * 1000000) [5] 21358 segmentation fault (core dumped) python3
在这里,输入是()重复的一百万次的字符串,这会导致CPython解析器崩溃。CPython开发人员不会将解析器中的错误视为安全问题。