Python - обновляет функцию / возвращает назначенную переменную - PullRequest
0 голосов
/ 12 апреля 2019

Сначала наберите код, чтобы вы поняли, о чем я говорю:

goal = False
count = 0
def function():
    if goal==True:
        return True
    else:
        return False
def func():
    if dict1["A"]==True:
        return True
    else:
        return False
dict1 = {"A":function()}
dict2 = {"B":func()}
list = [dict1,dict2]
goal = True
for i in list:
    count = 0
    for x,y in i.items():
        if y==True:
            count+=1
    if count==len(i):
        print("Works")
    else:
        print(i)

>>>{"A":False}
>>>{"B":False}

Это не мой текущий код, а актуальная проблема. Это где я спрашиваю, как я могу обновить значения в dicts. Должен ли я сделать что-то вроде:

for i in list:
    for x,y in i.items():
        y()

Мой текущий проект используется в Ren'Py (.rpy), но так как я использую блоки python, код работает точно так же, как обычный Python. Внутри класса с именем Event мои элементы выглядят так:

def ev_check(self):
    if self.done==False:
        self.count = 0
        for x,y in self.conditions.items():
            if y==True:
                self.count+=1
            else:
                pass
        if self.count==len(self.conditions):
            self.valid = True
        else:
            self.valid = False
    else:
        self.valid = False

def own_office():
    if Promotion_1.done==True: #Once the event is played, .done gets True
        return True
    else:
        return False

def times_worked(x):
    if You.worked < x:
        return False
    else:
        return True

Promotion_1.conditions = {"Work 2 times" : times_worked(2)}
Meet_Tigerr.conditions = {"Own office" : own_office()}
#External event that adds a value to the data named You.worked to get it to 2
print(Promotion_1.conditions["Work 2 times"])

>>> False

Ожидаемый результат: верно Результат: Ложь

1 Ответ

0 голосов
/ 12 апреля 2019

Вы можете создать свой собственный dict и иметь эту функцию. Вы можете попробовать что-то вроде этого:

class MyDict(dict):

    def __getitem__(self, item):
        val = super().__getitem__(item)
        if callable(val):
            return val()
        return val

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

d = MyDict()
d['m'] = 1
d['m']
Out[28]: 1
task
Out[33]: <function __main__.task()>
task()
Out[34]: True
d['t'] = task
d['t']
Out[36]: True

РЕДАКТИРОВАНИЕ: Немного изменил код, чтобы показать, как можно даже передавать значения аргументов для ваших параметризованных функций:

def func():
    return True


def param_func(i):
    return 2*i


def param_func2(i, j):
    return i*j


class MyDict(dict):

    def __getitem__(self, key):
        if isinstance(key, tuple):
            super_key = key[0]
        else:
            super_key = key
        super_val = super().__getitem__(super_key)
        if callable(super_val):
            if isinstance(key, tuple):
                args = key[1:]
                return super_val.__call__(*args)
            else:
                return super_val.__call__()
        return super_val


if __name__ == "__main__":
    d = MyDict()
    d['num'] = 1
    print(d['num'])
    d['func'] = func
    print(d['func'])
    d['param_func'] = param_func
    print(d['param_func', 2])
    d['param_func2'] = param_func2
    print(d['param_func2', 2, 6])

Выход:

1

Правда

4

12

...