pyclbr
--- Python モジュールブラウザサポート¶
ソースコード: Lib/pyclbr.py
The pyclbr
module provides limited information about the
functions, classes, and methods defined in a Python-coded module. The
information is sufficient to implement a module browser. The
information is extracted from the Python source code rather than by
importing the module, so this module is safe to use with untrusted code.
This restriction makes it impossible to use this module with modules not
implemented in Python, including all standard and optional extension
modules.
-
pyclbr.
readmodule
(module, path=None)¶ Return a dictionary mapping module-level class names to class descriptors. If possible, descriptors for imported base classes are included. Parameter module is a string with the name of the module to read; it may be the name of a module within a package. If given, path is a sequence of directory paths prepended to
sys.path
, which is used to locate the module source code.This function is the original interface and is only kept for back compatibility. It returns a filtered version of the following.
-
pyclbr.
readmodule_ex
(module, path=None)¶ Return a dictionary-based tree containing a function or class descriptors for each function and class defined in the module with a
def
orclass
statement. The returned dictionary maps module-level function and class names to their descriptors. Nested objects are entered into the children dictionary of their parent. As with readmodule, module names the module to be read and path is prepended to sys.path. If the module being read is a package, the returned dictionary has a key'__path__'
whose value is a list containing the package search path.
バージョン 3.7 で追加: Descriptors for nested definitions. They are accessed through the new children attribute. Each has a new parent attribute.
The descriptors returned by these functions are instances of Function and Class classes. Users are not expected to create instances of these classes.
Function オブジェクト¶
Class Function
instances describe functions defined by def
statements. They have the following attributes:
-
Function.
file
¶ Name of the file in which the function is defined.
-
Function.
module
¶ The name of the module defining the function described.
-
Function.
name
¶ 関数の名前です。
-
Function.
lineno
¶ The line number in the file where the definition starts.
-
Function.
parent
¶ For top-level functions, None. For nested functions, the parent.
バージョン 3.7 で追加.
-
Function.
children
¶ A dictionary mapping names to descriptors for nested functions and classes.
バージョン 3.7 で追加.
クラスオブジェクト¶
Class Class
instances describe classes defined by class
statements. They have the same attributes as Functions and two more.
-
Class.
file
¶ Name of the file in which the class is defined.
-
Class.
module
¶ The name of the module defining the class described.
-
Class.
name
¶ クラスの名前です。
-
Class.
lineno
¶ The line number in the file where the definition starts.
-
Class.
parent
¶ For top-level classes, None. For nested classes, the parent.
バージョン 3.7 で追加.
-
Class.
children
¶ A dictionary mapping names to descriptors for nested functions and classes.
バージョン 3.7 で追加.
-
Class.
super
¶ 記述しようとしている対象クラスの、直接の基底クラス群について記述している
Class
オブジェクトのリストです。スーパクラスとして挙げられているがreadmodule_ex()
が見つけられなかったクラスは、Class
オブジェクトではなくクラス名の文字列としてリストに挙げられます。
-
Class.
methods
¶ A dictionary mapping method names to line numbers. This can be derived from the newer children dictionary, but remains for back-compatibility.