Отсутствует переменная члена объекта Python

У меня есть конструктор, который создает объект члена подкласса:

class OpenSprinkler:
  class CV:
    my_args = ['rsn', 'rbt', 'en', 'rd', 're']
    my_longhand = {'reset_all':'rsn',
                   'reboot':'rbt',
                   'enable':'en',
                   'rain_delay':'rd',
                   'remote_extension':'re'}

    def __init__(self, p):
      print('set parent of %r\n' % (self,))
      self.parent = p
      print('parent set to %r\n' % (p,))
      self.my_args.extend(self.my_longhand.keys())

  def __init__(self, hostname, password, log=None):
    self.cv = self.CV(self)

выходные данные подтверждают, что конструктор для члена был вызван:

>>> c = openSprinkler.OpenSprinkler('foo','bar')
set parent of <openSprinkler.OpenSprinkler.CV object at 0xb6a58df0>

parent set to <openSprinkler.OpenSprinkler object at 0xb6a58dd0>

>>> repr(c.cv)
'<openSprinkler.OpenSprinkler.CV object at 0xb6a58df0>'

но когда я смотрю на членов, cv.parent не существует

>>> dir(c.cv)
['__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__gt__', '__hash__', '__init__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', 'my_args', 'my_longhand']

cv.my_args содержит расширенный список. Есть идеи, что здесь происходит?

ОБНОВЛЕНИЕ: Как указал Алек, пример кода действительно работает. Фактическая проблема была исключена из примера и заключалась в том, что я решил переопределить метод setattr, не позволяя установить parent.

первоначально:

def __setattr__(self, name, value):
  if name in self.my_args:
    if name in self.my_longhand.keys():
      name = self.my_longhand[name]
    self.parent._json_get('cv', {name:value})

сейчас:

def __setattr__(self, name, value):
  if name in self.my_args:
    if name in self.my_longhand.keys():
      name = self.my_longhand[name]
    self.parent._json_get('cv', {name:value})
  else:
    super().__setattr__(name, value)

1 ответ

Решение

Возможно ли, что у вас есть openSprinkler объект где-то еще в коде, который вызывается? Инстанцирование OpenSprinkler кажется, прямо содержит ваши методы:

c = OpenSprinkler('foo','bar')

print(dir(c.cv))
# ['__class__', '__delattr__', '__dict__', '__dir__', 
# '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', 
# '__gt__', '__hash__', '__init__', '__le__', '__lt__', 
# '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', 
# '__repr__', '__setattr__', '__sizeof__', '__str__', 
# '__subclasshook__', '__weakref__', 'my_args', 'my_longhand', 'parent']
Другие вопросы по тегам