Math Expression Evaluation

前端 未结 6 1164
感情败类
感情败类 2020-11-30 09:22

What is the best way to implement a python program that will take a string and will output its result according to operator precedence (for example: \"4+3*5\" will output 19

相关标签:
6条回答
  • 2020-11-30 09:45

    This receipe gives the proper answer to your problem:

    http://code.activestate.com/recipes/496746-restricted-safe-eval/

    It allows you to eval limited statement that can not harm your computer or your program.

    0 讨论(0)
  • 2020-11-30 09:47

    If you're "academically interested", you want to learn about how to write a parser with operator precedence.

    Simple Top-Down Parsing in Python is a nice article that builds an example parser to do exactly what you want to do: Evaluate mathematical expressions.

    I can highly recommend having a go at writing your own first parser -- it's one of those "ah, that's how that works" moments!

    0 讨论(0)
  • 2020-11-30 09:56

    That's what the "eval" function does in Python.

    result = eval(expression)
    

    Beware though it can do a whole lot more, primarily call functions, so to be safe you should make sure it can't access the locals or globals. Also, you can access the builtin methods, including the tricky import so you need to block access to that as well:

    result = eval(expression, {'__builtins__': None}, {})
    

    But that's only if you need security, that is if you allow anybody to type in any expression.

    Of course since you this way block all locla variables from use, then you don't have any variables to use, so to have that you need to pass in just those variables which should be accessed in the dictionaries.

    vars = {'__builtins__': None, 'x': x}
    result = eval(expression, vars, {})
    

    or similar.

    0 讨论(0)
  • 2020-11-30 09:59

    I'm not terribly familiar with Python and any extremely Pythonic methods, but you could look at the Interpreter pattern, which is defined in the Gang of Four book. It's designed for processing a "language", and mathematical expressions do follow a particular language with rules. In fact, the example on Wikipedia is actually a Java implementation of a RPN calculator.

    0 讨论(0)
  • 2020-11-30 10:05

    The java alternative is here http://code.google.com/p/expressionoasis/

    0 讨论(0)
  • 2020-11-30 10:11

    Another possibility is to look at Pyparsing, which is a general parser builder. It is more powerful than you need, but it may be faster to implement.

    0 讨论(0)
提交回复
热议问题