Python에서 인스턴스 변수를 얻는 방법은 무엇입니까?
-
01-07-2019 - |
문제
모든 클래스의 인스턴스 변수 배열을 가져오는 내장 메소드가 Python에 있습니까?예를 들어 다음 코드가 있는 경우:
class hi:
def __init__(self):
self.ii = "foo"
self.kk = "bar"
이 작업을 수행할 수 있는 방법이 있습니까?
>>> mystery_method(hi)
["ii", "kk"]
편집하다:나는 원래 클래스 변수를 잘못 요청했습니다.
해결책
모든 객체에는 __dict__
모든 변수와 해당 값을 포함하는 변수입니다.
이 시도
>>> hi_obj = hi()
>>> hi_obj.__dict__.keys()
다른 팁
vars() 사용
class Foo(object):
def __init__(self):
self.a = 1
self.b = 2
vars(Foo()) #==> {'a': 1, 'b': 2}
vars(Foo()).keys() #==> ['a', 'b']
적어도 클래스를 인스턴스화하지 않고서는 일반적으로 클래스만 주어진 인스턴스 속성을 얻을 수 없습니다.하지만 인스턴스가 주어지면 인스턴스 속성을 얻을 수 있고, 클래스가 주어지면 클래스 속성을 얻을 수 있습니다.'검사' 모듈을 참조하세요.인스턴스는 실제로 속성으로 무엇이든 가질 수 있기 때문에 인스턴스 속성 목록을 얻을 수 없으며, 예에서와 같이 이를 생성하는 일반적인 방법은 __init__ 메서드에서 인스턴스에 할당하는 것입니다.
클래스가 인스턴스에 허용하는 속성의 고정 목록인 슬롯을 클래스가 사용하는 경우는 예외입니다.슬롯에 대한 설명은 다음과 같습니다. http://www.python.org/2.2.3/descrintro.html, 그러나 슬롯에는 다양한 함정이 있습니다.이는 메모리 레이아웃에 영향을 미치므로 다중 상속이 문제가 될 수 있으며 일반적으로 상속에서는 슬롯도 고려해야 합니다.
Vars() 및 dict 메소드는 모두 OP가 게시한 예에서는 작동하지만 다음과 같이 "느슨하게" 정의된 객체에서는 작동하지 않습니다.
class foo:
a = 'foo'
b = 'bar'
호출할 수 없는 모든 속성을 인쇄하려면 다음 함수를 사용할 수 있습니다.
def printVars(object):
for i in [v for v in dir(object) if not callable(getattr(object,v))]:
print '\n%s:' % i
exec('print object.%s\n\n') % i
다음을 사용하여 객체에 특정 변수가 있는지 테스트할 수도 있습니다.
>>> hi_obj = hi()
>>> hasattr(hi_obj, "some attribute")
제안하다
>>> print vars.__doc__
vars([object]) -> dictionary
Without arguments, equivalent to locals().
With an argument, equivalent to object.__dict__.
즉, 본질적으로 __dict__를 래핑합니다.
귀하의 예에는 실제로 클래스 변수가 아닌 "인스턴스 변수"가 표시됩니다.
들여다보기 hi_obj.__class__.__dict__.items()
멤버 함수 및 포함 모듈과 같은 다른 클래스 멤버와 함께 클래스 변수의 경우.
class Hi( object ):
class_var = ( 23, 'skidoo' ) # class variable
def __init__( self ):
self.ii = "foo" # instance variable
self.jj = "bar"
클래스 변수는 클래스의 모든 인스턴스에서 공유됩니다.
OP 질문에 대한 직접적인 대답은 아니지만 함수의 범위에 어떤 변수가 있는지 알아내는 아주 좋은 방법이 있습니다.이 코드를 살펴보세요:
>>> def f(x, y):
z = x**2 + y**2
sqrt_z = z**.5
return sqrt_z
>>> f.func_code.co_varnames
('x', 'y', 'z', 'sqrt_z')
>>>
func_code 속성에는 모든 종류의 흥미로운 내용이 포함되어 있습니다.이를 통해 멋진 일을 할 수 있습니다.다음은 내가 이것을 어떻게 사용했는지에 대한 예입니다.
def exec_command(self, cmd, msg, sig):
def message(msg):
a = self.link.process(self.link.recieved_message(msg))
self.exec_command(*a)
def error(msg):
self.printer.printInfo(msg)
def set_usrlist(msg):
self.client.connected_users = msg
def chatmessage(msg):
self.printer.printInfo(msg)
if not locals().has_key(cmd): return
cmd = locals()[cmd]
try:
if 'sig' in cmd.func_code.co_varnames and \
'msg' in cmd.func_code.co_varnames:
cmd(msg, sig)
elif 'msg' in cmd.func_code.co_varnames:
cmd(msg)
else:
cmd()
except Exception, e:
print '\n-----------ERROR-----------'
print 'error: ', e
print 'Error proccessing: ', cmd.__name__
print 'Message: ', msg
print 'Sig: ', sig
print '-----------ERROR-----------\n'