Функциональная композиция Python
-
21-09-2019 - |
Вопрос
Я пытался реализовать функциональный состав с помощью хорошего синтаксиса, и вот что у меня есть:
from functools import partial
class _compfunc(partial):
def __lshift__(self, y):
f = lambda *args, **kwargs: self.func(y(*args, **kwargs))
return _compfunc(f)
def __rshift__(self, y):
f = lambda *args, **kwargs: y(self.func(*args, **kwargs))
return _compfunc(f)
def composable(f):
return _compfunc(f)
@composable
def f1(x):
return x * 2
@composable
def f2(x):
return x + 3
@composable
def f3(x):
return (-1) * x
print f1(2) #4
print f2(2) #5
print (f1 << f2 << f1)(2) #14
print (f3 >> f2)(2) #1
print (f2 >> f3)(2) #-5
Он отлично работает с целыми числами, но не удается в списках/кортежах:
@composable
def f4(a):
a.append(0)
print f4([1, 2]) #None
Где ошибка?
Решение
append
делает дополнение на месте, как сказал Игнасио Васкес-Абрамс (ну, подразумевается)-так что, пока вы можете исправить это, просто добавив return
Для вашей функции это будет иметь побочный эффект изменения аргумента, который он был передан:
@composable
def f4(a):
a.append(0)
return a
Лучше всего использовать следующий еще более краткий код, который также создает и возвращает новый объект:
@composable
def f4(a):
return a + [0]
Не связан с StackOverflow