Правильный способ указать состояние функций - PullRequest
0 голосов
/ 16 ноября 2018

У меня есть код с различными функциями. Внутри одного из них есть условие. Я должен проверить, возникает ли это условие для выполнения другой функции.

Какой правильный способ сделать это? Я пробовал что-то подобное, но это не работает

Пример:

class MyClass:
    def thisFunction(self):
        try: 
            "I'm doing things"
        except:
            self.stop = print("That's already done!")
    def thisOtherFunction(self):
        "I'm doing things with things done in thisFunction"
s = MyClass()
s.thisFunction()
if self.stop == None:
    s.thisOtherFunction()
else:
    pass

Большое спасибо!

Обновление

На самом деле это намного проще:

class MyClass:
    def thisFunction(self):
        try: 
            "I'm doing things"
        except:
            self.stop = print("That's already done!")
   def thisOtherFunction(self):
        try:
            "I'm doing things with things done in thisFunction"
        except:
            pass
s = myClass()
s.thisFunction()
s.thisOtherFunction()

Благодаря примеру Адама Смита я просто не думал об этом. Может быть, это не так уж и элегантно.

Update2 Другой способ - использовать def __init__ таким образом:

    class MyClass:
        def __init__(self):
             self.commandStop = False
        def thisFunction(self):
            try: 
                "I'm doing things"
            except:
                self.commandStop = True
        def thisOtherFunction(self):
            "I'm doing things with things done in thisFunction"
        def conditionToGo(self):
             if self.commandStop == False:
                 print("That's already done!")
             else:
                 s.thisOtherFunction()
s = myClass()
s.thisFunction()
s.conditionToGo()

1 Ответ

0 голосов
/ 16 ноября 2018

Раньше я делал шаблоны, где мне нужно было выполнить серию преобразований в значение, и каждый раз нужно проходить тест. Вы можете построить это с помощью:

def pipeline(predicate, transformers):
    def wrapped(value):
        for transformer in transformers:
            value = transformer(value)
            if not predicate(value):
                raise ValueError(f"{value} no longer satisfies the specified predicate.") 
        return value
    return wrapped

Затем, чтобы построить пример, скажем, мне нужно сделать некоторую математику для числа, но обеспечить , чтобы число никогда не становилось отрицательным.

operations = [
    lambda x: x+3,
    lambda x: x-10,
    lambda x: x+1000,
    lambda x: x//2
]

job = pipeline(lambda x: x>0, operations)
job(3)  # fails because the sequence goes 3 -> 6 -> (-4) -> ...
job(8)  # is 500 because 8 -> 11 -> 1 -> 1001 -> 500
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...