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开发人员不会将解析器中的错误视为安全问题。
热门推荐
10 对患者生日祝福语简短
11 结婚祝福语简短装备
12 周岁祝福语学生文案简短
13 订婚领证祝福语简短精辟
14 导师获奖祝福语大全简短
15 新婚购房祝福语简短精辟
16 牛年祝福语简短的爱人
17 送芒果的祝福语简短
18 送给学长毕业祝福语简短