Sie eine Parsing-Bibliothek wie pyPEG verwenden können, obwohl es Raum für improvment mehr tun, als dieses ist, dass Sie eine Grammatik wie folgt definieren können:
from pypeg2 import optional, List, Namespace
import re
number = re.compile(r'\d+')
binop = re.compile(r'\+|\*') # Exercise: Extend to other binary operators
class BinOp(Namespace):
grammar = binop
class Number(Namespace):
grammar = number, optional("."), optional(number)
class Expression(Namespace):
grammar = Number, optional(BinOp, Number)
class Equation(List):
grammar = Expression, optional("="), optional(Expression)
Sie können den Fehler behandeln, wenn ein ungültiger Ausdruck durchlaufen wird und verwenden Sie die Parse-Funktion Ausdrücke zu überprüfen:
>>> import pypeg2
>>> f = pypeg2.parse("3=3", Equation)
>>> f = pypeg2.parse("3 = 3", Equation)
>>> f = pypeg2.parse("3 + 3 = 3", Equation)
>>> f = pypeg2.parse("3 * 3 = 3", Equation)
>>> f = pypeg2.parse("3hi", Equation)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/usr/local/lib/python3.5/site-packages/pypeg2/__init__.py", line 669, in parse
raise parser.last_error
File "<string>", line 1
3hi
^
SyntaxError: expecting match on \d+
Ich weiß: P verwenden eval: P lol –
verwenden Sie es nur, wenn Sie die Eingabe vertrauen, und es ist nicht vom Benutzer –
'eval' offensichtlich nicht gut (weil' 'x, y'' ist eine ziemlich gültige Aussage in Python, die ein Tupel ergibt). Wahrscheinlich müssen Sie Ihren eigenen Rechner mit einer begrenzten Anzahl von Operationen schreiben. – user3159253