What does Python's eval() do?

前端 未结 10 2101
后悔当初
后悔当初 2020-11-22 01:48

In the book that I am reading on Python, it keeps using the code eval(input(\'blah\'))

I read the documentation, and I understand it, but I still do no

10条回答
  •  太阳男子
    2020-11-22 02:41

    Another option if you want to limit the evaluation string to simple literals is to use ast.literal_eval(). Some examples:

    import ast
    
    # print(ast.literal_eval(''))          # SyntaxError: unexpected EOF while parsing
    # print(ast.literal_eval('a'))         # ValueError: malformed node or string
    # print(ast.literal_eval('import os')) # SyntaxError: invalid syntax
    # print(ast.literal_eval('1+1'))       # 2: but only works due to a quirk in parser
    # print(ast.literal_eval('1*1'))       # ValueError: malformed node or string
    print(ast.literal_eval("{'a':1}"))     # {'a':1}
    

    From the docs:

    Safely evaluate an expression node or a string containing a Python literal or container display. The string or node provided may only consist of the following Python literal structures: strings, bytes, numbers, tuples, lists, dicts, sets, booleans, and None.

    This can be used for safely evaluating strings containing Python values from untrusted sources without the need to parse the values oneself. It is not capable of evaluating arbitrarily complex expressions, for example involving operators or indexing.

    As for why it's so limited, from the mailing list:

    Allowing operator expressions with literals is possible, but much more complex than the current implementation. A simple implementation is not safe: you can induce basically unbounded CPU and memory usage with no effort (try "9**9**9" or "[None] * 9**9").

    As for the usefulness, this function is useful to "read back" literal values and containers as stringified by repr(). This can for example be used for serialization in a format that is similar to but more powerful than JSON.

提交回复
热议问题