Utiliza este crédito para lanzar tus proyectos ahora en Digital Ocean, válido por 60 días
Índice del contenido
¿Cómo crear un comando en django?
¿Cómo crear un comando en django?
Has usado Django antes ¿no? Entonces, ya usaste algún comando de Django, pudo haber sido makemigrations, migrate, startproject, startapp algún otro. Pero, ¿alguna vez has creado alguno? Quizás no. Sigue leyendo para aprender como.
Crear un comando en django
Para crear un comando de django basta con crear una carpeta llamada management en el mismo nivel que tu archivo manage.py
mkdir management
Posteriormente, hay que crear una carpeta llamada commands dentro de esa carpeta
cd management/
mkdir commands
Ahora nos posicionamos dentro de esa carpeta y creamos un archivo con el nombre de nuestro comando
cd commands/
touch tucomando.py
Dentro de esta archivo crearemos una clase llamada Command que herede de BaseCommand, con un método llamado handle.
# management/command/tucomando.py
from django.core.management.base import BaseCommand, CommandError
class Command(BaseCommand):
help = 'help text'
def handle(self, *args, **options):
pass
Dentro del método handle colocaremos el código que se ejecutará cuando usemos nuestro comando.
from django.core.management.base import BaseCommand, CommandError
class Command(BaseCommand):
help = 'help text'
def handle(self, *args, **options):
self.stdout.write(self.style.ERROR("Texto de error"))
self.stdout.write(self.style.WARNING("Texto de advertencia"))
Para mostrar texto en la terminal usaremos self.stdout.write para imprimir texto en la salida estándar. Podemos seleccionar entre varios estilos de acuerdo a lo que queramos mostrar.
¿Necesitas aprender todo lo que ofrece Django?
PatrocinadoPara dominar Django hay que entender como funciona, como una petición HTTP va al router, que pasa los datos de la petición a la función (o clase) adecuada y luego como se puede el ORM de Django para interactuar con la base de datos y devolver una respuesta si quieres una explicación detallada de cada paso, educative tiene un curso sobre eso, con certificado incluido, y se cubre Python (por si no sabes Python) link abajo.
Añadir argumentos al comando
Django usa la famosa librería argparse de Python para manejar los argumentos en sus comandos
Argumentos posicionales
Podemos añadir argumentos posicionales al comando usando el método add_argument de parser.
from django.core.management.base import BaseCommand, CommandError
class Command(BaseCommand):
help = 'help text'
def add_arguments(self, parser):
parser.add_argument('email', nargs='+', type=str)
Especificamos el nombre del argumento posicional como primer argumento, luego la cantidad de argumentos que recibirá. El símbolo ‘+’ establece que esos argumentos serán colocados en una lista, mientras que type es el tipo de valores que recibirá el argumento.
Seguramente ya habrás notado que la función handle recibe *args y **options como argumento. Bien, pues podemos acceder a los valores a través del diccionario options.
from django.core.management.base import BaseCommand, CommandError
class Command(BaseCommand):
help = 'help text'
def add_arguments(self, parser):
parser.add_argument('email', nargs='+', type=str)
def handle(self, *args, **options):
# options['email'] es una lista
send_emails(options['email'])
Argumentos opcionales
¿Y si yo quiero argumentos opcionales? Pues sí, también es posible.
La clase Command, a través de su parser, también nos permite usar argumentos opcionales.
from django.core.management.base import BaseCommand, CommandError
class Command(BaseCommand):
help = 'help text'
def add_arguments(self, parser):
# Named (optional) arguments
parser.add_argument(
'--file',
nargs='?',
const='logo.svg',
type=str,
help='texto de ayuda',
)
def handle(self, *args, **options):
if options['file'].endswith('.svg'):
process_svg()
Ahora seguramente te estarás preguntando que significan todos esos argumentos que le pasamos a add_argument.
Ahora mismo te lo digo:
- Prefijo ‘–’: le dice a Argparse que es un argumento opcional
- nargs: indica la cantidad de valores que puede recibir nuestro argumento, el simbolo ‘+’ en este caso es para uno o ninguno.
- const: es el valor a usar si no especificamos ningún valor para el argumento.
- type: nos dice el tipo de dato que espera nuestro argumento.
- help: es el texto de ayuda a mostrar.
Ejecutar el comando
¿Y para ejecutarlo? Fácil; justo como lo harías con cualquier otro comando de django.
python manage.py tucomando
# con un argumento posicional
python managa.py tucomando email [email protected]
# o con un argumento opcional
python manage.py tuotrocomando --file=tuarchivo.svg
Listo, si te leiste esto completo, ahora conoces lo básico de la creación de comandos de django. Pero no te quedes solo con esto, visita la documentación oficial de django para profundizar más.