문제

모든 클래스의 인스턴스 변수 배열을 가져오는 내장 메소드가 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'
라이센스 : CC-BY-SA ~와 함께 속성
제휴하지 않습니다 StackOverflow
scroll top