Подтвердить что ты не робот

Python, используя методы из других классов

Если у меня есть два класса, и у одного из них есть функция, которую я хочу использовать в моем другом классе, что я использую, чтобы мне не пришлось переписывать мою функцию?

4b9b3361

Ответ 1

Есть два варианта:

  • инициализировать объект в вашем классе, а затем вызвать желаемый метод на нем
  • используйте @classmethod, чтобы превратить функцию в метод класса

Пример:

class A(object):
    def a1(self):
        """ This is an instance method. """
        print "Hello from an instance of A"

    @classmethod
    def a2(cls):
        """ This a classmethod. """
        print "Hello from class A"

class B(object):
    def b1(self):
        print A().a1() # => prints 'Hello from an instance of A'
        print A.a2() # => 'Hello from class A'

Или используйте наследование, если необходимо:

class A(object):
    def a1(self):
        print "Hello from Superclass"

class B(A):
    pass

B().a1() # => prints 'Hello from Superclass'

Ответ 2

Существует несколько подходов:

  •   
  • Наследование  
  • Делегирование  
  • Супер-подлая делегия

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

Наследование

class Common(object):
    def __init__(self,x):
        self.x = x
    def sharedMethod(self):
        print self.x

class Alpha(Common):
    def __init__(self):
        Common.__init__(self,"Alpha")

class Bravo(Common):
    def __init__(self):
        Common.__init__(self,"Bravo")

Делегирование

class Common(object):
    def __init__(self,x):
        self.x = x
    def sharedMethod(self):
        print self.x

class Alpha(object):
    def __init__(self):
         self.common = Common("Alpha")
    def sharedMethod(self):
         self.common.sharedMethod()

class Bravo(object):
    def __init__(self):
         self.common = Common("Bravo")
    def sharedMethod(self):
         self.common.sharedMethod()

Супер-подлая делегия
Это решение основано на том факте, что нет ничего особенного в функциях-членах Python; вы можете использовать любую функцию или вызываемый объект, если первый параметр интерпретируется как экземпляр класса.

def commonPrint(self):
    print self.x

class Alpha(object):
    def __init__(self):
        self.x = "Alpha"
    sharedMethod = commonPrint

class Bravo(object):
    def __init__(self):
        self.x = "Bravo"
    sharedMethod = commonPrint

Или аналогичным образом скрытый способ достижения делегирования - использовать вызываемый объект:

class Printable(object):
   def __init__(self,x):
       self.x = x
   def __call__(self):
       print self.x

class Alpha(object):
   def __init__(self):
       self.sharedMethod = Printable("Alpha")

class Bravo(object):
   def __init__(self):
       self.sharedMethod = Printable("Bravo")

Ответ 3

вы создаете класс, из которого оба класса наследуют.

Существует множественное наследование, поэтому, если у них уже есть родительский элемент, это не проблема.

class master ():
    def stuff (self):
        pass

class first (master):
    pass


class second (master):
    pass


ichi=first()
ni=second()

ichi.stuff()
ni.stuff()