Python 类浏览器支持


Python 库中的 **pyclbr** 模块可以提取关于在 Python 模块中定义的函数、类和方法的信息。这些信息是从 Python 源代码中提取的,而不是通过导入模块来获取。

此模块定义了 **readmodule()** 函数,该函数返回一个字典,将模块级类名映射到类描述符。该函数采用模块名作为参数。它可能是包中模块的名称。在这种情况下,path 是一个目录路径序列,添加到 sys.path 前面,用于定位模块源代码。

以下代码使用 readmodule() 函数来解析 Python 库的 socket 模块中的类和方法。

import pyclbr

mod = pyclbr.readmodule("socket")

def show(c):
   s = "class " + c.name
   print (s + ":")
   methods = c.methods.items()
   for method, lineno in methods:
      print (" def " + method)
   print()

for k, v in mod.items():
   show(v)
class IntEnum:

class IntFlag:
   def _missing_
   def _create_pseudo_member_
   def __or__
   def __and__
   def __xor__
   def __invert__

class _GiveupOnSendfile:

class socket:
   def __init__
   def __enter__
   def __exit__
   def __repr__
   def __getstate__
   def dup
   def accept
   def makefile
   def _sendfile_use_sendfile
   def _sendfile_use_send
   def _check_sendfile_params
   def sendfile
   def _decref_socketios
   def _real_close
   def close
   def detach
   def family
   def type
   def get_inheritable
   def set_inheritable

class SocketIO:
   def __init__
   def readinto
   def write
   def readable
   def writable
   def seekable
   def fileno
   def name
   def mode
   def close

pyclbr 模块还定义了 **readmodule_ex()** 函数,该函数返回一个字典,其中包含模块中定义的每个函数或类描述符。返回的字典将模块级函数和类名映射到它们的描述符。嵌套对象被输入到其父对象的 children 字典中。

>>> x = pyclbr.readmodule_ex('socket')

>>> for k,v in x.items():
print (k,v)


IntEnum <pyclbr.Class object at 0x000002095D7D0048>
IntFlag <pyclbr.Class object at 0x000002095D7D04E0>
_intenum_converter <pyclbr.Function object at 0x000002095D82F940>
_GiveupOnSendfile <pyclbr.Class object at 0x000002095D822898>
socket <pyclbr.Class object at 0x000002095D8227B8>
fromfd <pyclbr.Function object at 0x000002095D8340B8>
fromshare <pyclbr.Function object at 0x000002095D82FEF0>
socketpair <pyclbr.Function object at 0x000002095D834128>
SocketIO <pyclbr.Class object at 0x000002095D82FA20>
getfqdn <pyclbr.Function object at 0x000002095D8344E0>
create_connection <pyclbr.Function object at 0x000002095D834518>
getaddrinfo <pyclbr.Function object at 0x000002095D834550>

这些函数也可以与自定义模块一起使用,以获取用户定义的类和方法的目录。

在下面的示例中,使用模块 'triangles.py' 来获取其类结构。

#triangles.py
import math
class Triangle:
   def __init__(self, a, b, c):
      self.a = a
      self.b = b
     self.c = c
   def area(self):
      s=(self.a+self.b+self.c)/2
      area=math.sqrt(s*(s-self.a)*(s-self.b)*(s-self.c))
      return area
class EquiTriangle(Triangle):
   def __init__(self, a):
      b = a
      c = a
      super().__init__(a,b,c)
   def area(self):
      area=math.sqrt(3)*pow(self.a,2)/4
      return area

我们现在将获取 'triangles' 模块中的类和方法。

>>> br = pyclbr.readmodule_ex('triangles')
>>> for i,j in br.items(): print (i,j.methods)

Triangle {'__init__': 3, 'area': 7}
EquiTriangle {'__init__': 12, 'area': 16}

pyclbr 模块定义了两个对象——类对象和函数对象。

**函数** 对象具有以下属性:

file
 定义函数的文件名。
module
 定义所描述函数的模块名。
name
 函数名。
lineno
 文件中定义开始的行号。
parent
 对于顶级函数,为 None。对于嵌套函数,为其父函数。
children
 一个字典,将名称映射到嵌套函数和类的描述符。

除了上述属性外,**类** 对象还有两个额外的属性:

super
 一个类对象列表,描述正在描述的类的直接基类。
methods
 一个字典,将方法名映射到行号。

更新于:2019年7月30日

225 次查看

启动你的 职业生涯

通过完成课程获得认证

开始
广告
© . All rights reserved.