Aprendiendo Python (VII). Docstrings
Tutorial sobre docstrings en Python 3
Python es un lenguaje que se considera autodocumentado por su sencillez a la hora de ser leído. Ahora bien, cuando trabajamos en un proyecto que va creciendo en dificultad, los comentarios son dios y nosotros sus fieles y acérrimos seguidores. Nunca se pasa tan mal como cuando heredas un proyecto sin una línea de comentarios, ni un punto y coma de documentación.
Lo ideal es crear una API, que describa que es, que hace, cada objeto. ¿Qué sucede? Que a la larga es difícil de mantener, da pereza, etc.
Y ahí es cuando Python entra con su maravilloso docstrings.
Esta documentación tiene una serie de reglas, a saber:
- Cualquier clase, función o método puede tener un string Python estándar que tiene que localizarse en la primera línea después de la definición (la línea que termina con dos puntos).
- Ésta línea deberá estar identada al mismo nivel que el código que contenga la clase, función o método.
- Debe explicar los parámetros que no queden muy claros
- En caso de que se retorne algún valor también deberá indicarse
Es decir, que nuestra clase que llevamos trabajando en las anteriores entradas quedaría tal que así:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
class NombreDeLaClase:
'''
Establece una fecha basada en el día y el mes
'''
def __init__(self, dia, mes):
'''
Inicializa la nueva fecha
Params:
- dia. Entero indicando el día de la fecha
- mes. Entero indicando el mes de la fecha
'''
self.nueva_fecha(dia, mes)
def nueva_fecha(self, dia, mes):
'''
Establece una nueva fecha
Params:
- dia. Entero indicando el día de la fecha
- mes. Entero indicando el mes de la fecha
'''
self.dia = dia
self.mes = mes
def reiniciar(self):
'''
Reinicia la fecha a un valor por defecto
Params:
- 1. Entero. Día
- 1. Entero. Mes
'''
self.nueva_fecha(1, 1)
def diferencia_mes(self, otra_fecha):
'''
Devuelve la diferencia de meses entre dos fechas
Params:
- self. Nuestro objeto
- otra_fecha. Objeto NombreDeLaClase inicializado
Returns:
- Entero indicando la diferencia de meses
'''
if (self.mes > otra_fecha.mes):
return self.mes - otra_fecha.mes
else:
return otra_fecha.mes - self.mes
Ahora guardaremos el archivo con un nombre de nuestra elección. En mi caso, ejemploDocstrings.py.
Nos vamos a la consola de comandos y lanzamos nuestro programa en modo interacción con el siguiente comando
1
python -i ejemploDocstrings.py
Nos aparecerá un prompt esperando nuestros comandos, cosas que indica que nuestra clase ya se ha cargado y, si queremos ver el docstring en formato API que nos genera Python, escribiremos
1
help(NombreDeLaClase)
y veremos como automaticamente nos aparece un documento con los comentarios que hemos creado
Al poder crearse tan sencillamente, incluso podemos crearnos un script que con cada actualización nos genere la documentación de nuestro proyecto, para tenerlo constantemente actualizado.
Pronto regresare con una nueva entrada
¡Salud y coding!