如何使用inspect或__doc__方法打印python方法文档

时间:2015-03-02 23:27:46

标签: python

我有以下代码:

import os
import imp
import sys
import inspect
import urlparse
from cgi import escape

def get_module(ClassName, Path):
    fp, pathname, description = imp.find_module(ClassName, [Path])
    module_loaded = imp.load_module(ClassName, fp, pathname, description)
    return module_loaded


def get_class_members(className):
    print "Members of  "+str(className)
    member_functions = inspect.getmembers(className,    predicate=inspect.ismethod)
    for each_item in member_functions:
        print each_item[0].__doc__

def get_all_classes(path, module):

    module_loaded = None
    sys.path.append(path)

    module_loaded = get_module(module, path)

    if None != module_loaded:
        class_list = module_loaded.get_all_classes()
        print "classes are "+str(class_list)
        return class_list




def main():
    class_list = get_all_classes('.', 'Class_Interface_File')
    for each_class in class_list:
        temp_module = get_module(each_class, '.')
        my_class = getattr(temp_module, each_class)
        instance = my_class()
        get_class_members(instance)
        print "-----------"

if __name__ == "__main__":
    main()

Class_Interface_file返回一个类名示例列表[' Social',' Audio'] 我在方法get_class_members中有问题。我想通过inspect.getmembers打印我发现的每个成员函数的注释。我不知道如何使用each_item的值来连接className。

或是否可以直接打印来自each_item的成员函数文档?

请帮忙解决这个问题。

1 个答案:

答案 0 :(得分:0)

好的,有些玩弄你的代码......

我在模块三角形中有一个类Triangle,有一些方法。

>>>import inspect
>>>import triangle
>>>mems = inspect.getmembers(triangle.Triangle)
>>>mems
[('__doc__', None), ('__init__','<unboound method.....>), etc)]

getmembers()返回元组列表。 所以在你的代码循环中,你要求each_item[0].__doc__,[0]引用包含函数名称的字符串。因此该行只返回字符串对象的__doc__。将此值更改为[1]将返回实际方法的__doc__

>>>mems[3][0]  #the name of the function itself
'drawEquilateral'
>>>#here I reference the second tuple element of the fourth member
...
>>>mems[3][1].__doc__
'draw an equilateral triangle'
>>>"Method %s:  %s" %(mems[3][0], mems[3][1].__doc__)
'Method drawEquilateral: draw an equilateral triangle'

希望这有帮助。