回答:
すべてのオブジェクトには、__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)
か?
通常、クラスだけを指定してインスタンス属性を取得することはできません。少なくとも、クラスをインスタンス化しないと取得できません。ただし、インスタンスが指定されたインスタンス属性、またはクラスが指定されたクラス属性を取得できます。'inspect'モジュールを参照してください。インスタンスは属性として何でも持つことができるため、インスタンス属性のリストを取得することはできません。また、例のように、インスタンスを作成する通常の方法は、__ 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)
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'