9

到目前为止,这是我的代码,

import win32com.client as winc

outlook = winc.Dispatch("Outlook.Application").GetNamespace("MAPI")
inbox = outlook.GetDefaultFolder(6)
messages = inbox.Items
message = messages.GetLast()
print message.body

message.body从 Outlook 打印我的最后一封电子邮件。

当我dir(message)help(message)属性body不来。为什么?

>>> dir(message)
['_ApplyTypes_', '_FlagAsMethod', '_LazyAddAttr_', '_NewEnum', '_Release_', '__AttrToID__', '__LazyMap__', '__call__', '__doc__', '__eq__', '__getattr__', '__getitem__', '__init__', '__int__', '__len__', '__module__', '__ne__', '__nonzero__', '__repr__', '__setattr__', '__setitem__', '__str__', '_builtMethods_', '_enum_', '_find_dispatch_type_', '_get_good_object_', '_get_good_single_object_', '_lazydata_', '_make_method_', '_mapCachedItems_', '_oleobj_', '_olerepr_', '_print_details_', '_proc_', '_unicode_to_string_', '_username_', '_wrap_dispatch_']

为什么是这样?

更新

无论如何我可以毫无疑问地了解对象的所有属性吗?

4

3 回答 3

10

根据此页面http://docs.python.org/2/library/functions.html#dir

因为提供 dir() 主要是为了方便在交互式提示下使用,所以它尝试提供一组有趣的名称,而不是尝试提供一组严格或一致定义的名称,并且它的详细行为可能会随版本而变化。例如,当参数是类时,元类属性不在结果列表中。

所以,我们不应该依赖于dir去了解一个对象的一切。如果该类实现__dir__方法,我们将只得到从该方法返回的任何内容。他们可能已经实现并从调用中__dir__抽象出来。bodydir

例子:

class TestClass:
    def __init__(self):
        self.myValue = 0
    def myMethod(self):
        pass
    def __dir__(self):
        return []

class TestClass1:
    def __init__(self):
        self.myValue = 0
    def myMethod(self):
        pass

print dir(TestClass())
print dir(TestClass1())

print dir(TestClass())
print dir(TestClass1())

输出

[]
['__doc__', '__init__', '__module__', 'myMethod', 'myValue']
于 2013-10-24T11:12:16.720 回答
1

尝试使用__dict__方法。正如它在文档中指定的那样,它列出了所有可写属性,所以这可能会有所帮助。

于 2013-10-24T11:16:36.860 回答
0

答案是否定的,因为在这种情况下,对象的__getattr__方法可以被覆盖。考虑以下示例:

>>> class Const(object):
...     def __init__(self, val):
...         self.value = val
...     def __getattr__(self, a):
...         return self.value
...     def __setattr__(self, a, v)
...         self.__dict__[a] = v
...
>>> c = Const(1)
>>> dir(c)
['__class__', '__delattr__', '__dict__',  '__doc__', '__format__', '__getattr__', '__getattribute__', '__hash__', '__init__', '__module__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', 'value']
>>> c.__dict__
{'value': 1}
>>> c.some_strange_attribute_name
1
>>> c.some_strange_attribute_name = 2
>>> c.some_strange_attribute_name
2
于 2013-10-24T11:19:35.480 回答