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
'programing' 카테고리의 다른 글
파이썬에서 반복기를 청크(n개)별로 반복합니까? (0) | 2023.07.16 |
---|---|
python-dotenv의 용도는 무엇입니까? (0) | 2023.07.16 |
Python에서 콘솔 출력 바꾸기 (0) | 2023.07.16 |
기본 키와 대리 키의 차이점은 무엇입니까? (0) | 2023.07.16 |
PySpark에서 데이터 프레임 열을 String 유형에서 Double 유형으로 변경하는 방법은 무엇입니까? (0) | 2023.07.16 |