답변:
모든 개체에는 __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']
__method
비공개이며, __method__
반드시 비공개가 아닌 특별한 방법입니다. 특별한 방법이 방법보다는 객체의 기능을 정의한다고 말하고 싶습니다.
__method__
아주 추하고, 절대적으로 필요한 경우가 아니라면 사람들이 사용하지 못하도록 막기 위해 이름이 붙여진 것 같습니다. 이 경우 대체 vars ()가 있습니다.
__str__
, __method__
일반적으로 언어 자체에 대한 것입니다. 당신은 어떻게됩니까 str(something)
?
일반적으로 클래스를 인스턴스화하지 않고는 클래스에만 주어진 인스턴스 속성을 가져올 수 없습니다. 하지만 주어진 인스턴스 속성이나 클래스가 주어진 클래스 속성을 얻을 수 있습니다. '검사'모듈을 참조하십시오. 인스턴스는 실제로 어떤 것도 속성으로 가질 수 있기 때문에 인스턴스 속성 목록을 가져올 수 없으며, 예제에서와 같이 일반적인 방법은 __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
exec('print object.%s\n\n') % i
다음과 같이 작성되어야합니다.print getattr(object, i)
귀하의 예제는 실제로 클래스 변수가 아닌 "인스턴스 변수"를 보여줍니다.
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'