pyclbr
— Soporte para navegador de módulos Python¶
Código fuente: Lib/pyclbr.py
El módulo pyclbr
proporciona información limitada sobre las funciones, clases y métodos definidos en un módulo de Python. La información es suficiente para implementar un navegador de módulos. La información se extrae del código fuente de Python en lugar de importar el módulo, por lo que este módulo es seguro de usar con código que no es de confianza. Esta restricción hace que sea imposible utilizar este módulo con módulos no implementados en Python, incluidos todos los módulos de extensión estándar y opcionales.
- pyclbr.readmodule(module, path=None)¶
Retorna un diccionario que asigna nombres de clase a nivel de módulo con descriptores de clase. Si es posible, se incluyen descriptores para las clases base importadas. El parámetro module es una cadena con el nombre del módulo que se va a leer; puede ser el nombre de un módulo dentro de un paquete. Si se indica, path es una secuencia de rutas de directorios antepuesto a
sys.path
, que se utiliza para localizar el código fuente del módulo.Esta función es la interfaz original y sólo se mantiene por compatibilidad. Retorna una versión filtrada de lo siguiente.
- pyclbr.readmodule_ex(module, path=None)¶
Retorna un árbol basado en diccionarios que contiene un descriptor de función o clase para cada función y clase definida en el módulo con una instrucción
def
oclass
. El diccionario retornado asigna nombres de clase y función a nivel de módulo con sus descriptores. Los objetos anidados se introducen en el diccionario hijo de su elemento padre. Al igual que con readmodule, module nombra el módulo que se va a leer y path se antepone a sys.path. Si el módulo que se lee es un paquete, el diccionario retornado tiene una clave'__path__'
cuyo valor es una lista que contiene la ruta del paquete.
Nuevo en la versión 3.7: Descriptores para definiciones anidadas. Se accede a ellos a través del nuevo atributo children. Cada uno tiene un nuevo atributo parent.
Los descriptores retornados por estas funciones son instancias de las clases Function y Class. No se espera que los usuarios creen instancias de estas clases.
Objetos Function¶
- class pyclbr.Function¶
Class
Function
instances describe functions defined by def statements. They have the following attributes:- file¶
Nombre del archivo en el cual la función está definida.
- module¶
El nombre del módulo que define la función descrita.
- name¶
El nombre de la función.
- lineno¶
El número de línea el en archivo donde inicia la definición.
- parent¶
For top-level functions,
None
. For nested functions, the parent.Nuevo en la versión 3.7.
- children¶
A
dictionary
mapping names to descriptors for nested functions and classes.Nuevo en la versión 3.7.
Objetos Class¶
- class pyclbr.Class¶
Class
Class
instances describe classes defined by class statements. They have the same attributes asFunctions
and two more.- file¶
Nombre del archivo en el que la clase está definida.
- module¶
Nombre del módulo que define la clase descrita.
- name¶
El nombre de la clase.
- lineno¶
El número de línea el en archivo donde inicia la definición.
- parent¶
Para clases en el nivel más alto, None. Para clases anidadas, el padre.
Nuevo en la versión 3.7.
- children¶
Un diccionario asignando nombres con descriptores para las clases y funciones anidadas.
Nuevo en la versión 3.7.
- super¶
A list of
Class
objects which describe the immediate base classes of the class being described. Classes which are named as superclasses but which are not discoverable byreadmodule_ex()
are listed as a string with the class name instead of asClass
objects.
- methods¶
A
dictionary
mapping method names to line numbers. This can be derived from the newerchildren
dictionary, but remains for back-compatibility.