web-dev-qa-db-ja.com

文字列を演算子に変換

"+"などの文字列を演算子plusに変換するにはどうすればよいですか?ありがとう!

36
hwong557

ルックアップテーブルを使用します。

import operator
ops = { "+": operator.add, "-": operator.sub } # etc.

print ops["+"](1,1) # prints 2 
82
Amnon
import operator

def get_operator_fn(op):
    return {
        '+' : operator.add,
        '-' : operator.sub,
        '*' : operator.mul,
        '/' : operator.div,
        '%' : operator.mod,
        '^' : operator.xor,
        }[op]

def eval_binary_expr(op1, oper, op2):
    op1,op2 = int(op1), int(op2)
    return get_operator_fn(oper)(op1, op2)

print eval_binary_expr(*("1 + 3".split()))
print eval_binary_expr(*("1 * 3".split()))
print eval_binary_expr(*("1 % 3".split()))
print eval_binary_expr(*("1 ^ 3".split()))

[〜#〜] edit [〜#〜]:最適化されたバージョンで、呼び出しごとではなく、コンパイル時にオペレーター関数マップを作成し、getメソッド解決を解決します:

def eval_binary_expr(op1, oper, op2,
                     get_operator_fn={
                         '+' : operator.add,
                         '-' : operator.sub,
                         '*' : operator.mul,
                         '/' : operator.div,
                         '%' : operator.mod,
                         '^' : operator.xor,
                         }.get):
    op1,op2 = int(op1), int(op2)
    return get_operator_fn(oper)(op1, op2)
15
PaulMcG

Eval()を使用してみることができますが、文字列が自分のものでない場合は危険です。それ以外の場合は、辞書の作成を検討してください。

ops = {"+": (lambda x,y: x+y), "-": (lambda x,y: x-y)}

など...そして電話

ops['+'] (1,2)

if ops.haskey(userop):
    val = ops[userop](userx,usery)
else:
    pass #something about wrong operator

ルックアップ辞書を使用するのはどうですか。ただし、演​​算子ライブラリの代わりにラムダを使用します。

op = {'+': lambda x, y: x + y,
      '-': lambda x, y: x - y}

次に、次のことができます。

print(op['+'](1,2))

そしてそれは出力します:

3
3
Garrett

すべてのオペレーターに対応する魔法のメソッドがあります

OPERATORS = {'+': 'add', '-': 'sub', '*': 'mul', '/': 'div'}

def apply_operator(a, op, b):

    method = '__%s__' % OPERATORS[op]
    return getattr(b, method)(a)

apply_operator(1, '+', 2)

私の意見では、アムノンが提案した答えは正しいものです。

ただし、数学パーサーに関するこの記事にも興味がある可能性があります。 http://effbot.org/zone/simple-top-down-parsing.htm

1
luc

同じ問題があり、Jupyter Notebookを使用して、演算子モジュールをインポートできませんでした。したがって、上記のコードは私に洞察を与えるのに役立ちましたが、プラットフォームで実行できませんでした。私はすべての基本的な機能でそうするためのやや原始的な方法を見つけました、そしてそれはここにあります:(これはかなり洗練されているかもしれませんが、それは始まりです...)

# Define Calculator and fill with input variables
# This example "will not" run if aplha character is use for num1/num2 
def calculate_me():
    num1 = input("1st number: ")
    oper = input("* OR / OR + OR - : ")
    num2 = input("2nd number: ")

    add2 = int(num1) + int(num2)
    mult2 = int(num1) * int(num2)
    divd2 = int(num1) / int(num2)
    sub2 = int(num1) - int(num2)

# Comparare operator strings 
# If input is correct, evaluate operand variables based on operator
    if num1.isdigit() and num2.isdigit():
        if oper is not "*" or "/" or "+" or "-":
            print("No strings or ints for the operator")
        else:
            pass
        if oper is "*":
            print(mult2)
        Elif oper is "/":
            print(divd2)
        Elif oper is "+":
            print(add2)
        Elif oper is "-":
            print(sub2)
        else:
            return print("Try again")

# Call the function
calculate_me()
print()
calculate_me()
print()
0
Kamron Hopkins

私はあなたが次のようなことをしたいことを理解しています:5 "+" 7で、3つすべてが変数によって渡されるので、例:

import operator

#define operators you wanna use
allowed_operators={
    "+": operator.add,
    "-": operator.sub,
    "*": operator.mul,
    "/": operator.truediv}

#sample variables
a=5
b=7
string_operator="+"

#sample calculation => a+b
result=allowed_operators[string_operator](a,b)
print(result)
0
Pawel Szewczyk