programing

Python에서 인스턴스 변수를 가져오는 방법은 무엇입니까?

lastmoon 2023. 7. 16. 17:44
반응형

Python에서 인스턴스 변수를 가져오는 방법은 무엇입니까?

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()

산출량

dict_keys(['ii', 'kk'])

변수 사용()

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")
False
>>> hasattr(hi_obj, "ii")
True
>>> hasattr(hi_obj, "kk")
True

예제에서는 클래스 변수가 아닌 "인스턴스 변수"를 보여 줍니다.

들여다보기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"

클래스 변수는 클래스의 모든 인스턴스에서 공유됩니다.

제안하다

>>> print vars.__doc__
vars([object]) -> dictionary

Without arguments, equivalent to locals().
With an argument, equivalent to object.__dict__.

즉, 기본적으로 __dict__을 감쌀 뿐입니다.

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'

경우에 따라 공용/개인 변수를 기준으로 목록을 필터링할 수 있습니다.예.

def pub_vars(self):
    """Gives the variable names of our instance we want to expose
    """
    return [k for k in vars(self) if not k.startswith('_')]

다음을 얻기 위해 dmark의 답을 기반으로 합니다. sprintf의 등식을 원한다면 유용하고 바라건대 누군가에게 도움이 될 것입니다.

def sprint(object):
    result = ''
    for i in [v for v in dir(object) if not callable(getattr(object, v)) and v[0] != '_']:
        result += '\n%s:' % i + str(getattr(object, i, ''))
    return result

먼저 클래스를 검사하고 다음으로 바이트 코드에서 함수를 검사한 다음 바이트 코드를 복사하고 마지막으로 를 사용해야 합니다.일부 클래스는 모듈과 같은 생성자를 사용하여 메서드를 만들기 때문에 이 작업까다롭습니다.GitHub에서 코드를 제공하겠습니다.

에단 조페의 대답에 근거합니다.

def print_inspect(obj):
  print(f"{type(obj)}\n")
  var_names = [attr for attr in dir(obj) if not callable(getattr(obj, attr)) and not attr.startswith("__")]
  for v in var_names: 
    print(f"\tself.{v} = {getattr(obj, v)}\n")

언급URL : https://stackoverflow.com/questions/109087/how-to-get-instance-variables-in-python

반응형