El ecosistema de Python ofrece muchas opciones de frameworks para hacer un API. Recomendamos que elijas entre estos dos stacks para construir tu app.
Flask es un microframework para desarrollo web en Python, proporcionando las herramientas básicas para crear una aplicación web sin incluir muchas de las funcionalidades preinstaladas que tienen otros frameworks más grandes. Esto permite una mayor flexibilidad y control, pero también significa que puede que necesites instalar paquetes adicionales para funcionalidades más avanzadas. Flask es un framework que permite ambos estilos de programación: funcional y orientado a objetos (basado en clases).
- Flask documentación Oficial
- Flask Quickstart
- Postgresql: como base de datos
Django es un framework web que fomenta el desarrollo rápido y limpio de aplicaciones web, el cual es pensado para fomentar la escalabilidad en el desarrollo.
Entre las características más importantes es que Django trabaja con su propio ORM (Object Relational Mapper) para facilitar la interacción con la base de datos.
Django es una excelente opción para desarrollar aplicaciones web complejas que requieren una amplia variedad de funcionalidades integradas, una arquitectura MVT (Model View Template) sólida y una gran comunidad de apoyo.
- Django: como framework para implementar un servidor HTTP.
- Django REST Framework: como biblioteca complementaria para crear APIs web RESTful.
- Postgresql: como base de datos.
Para trabajar con Django puedes usar entornos virtuales en el siguiente video puedes guiarte para crear un entorno virtual, también hemos preparado un video que ejemplifica la forma en como inicializar un proyecto con Django.
Una vez tengas acceso a una instancia de PostgreSQL, la historia de usuaria 1 nos habla de crear las tablas para cargar la información. Uno de los caminos que te sugerimos es:
- Crear los modelos
- Después, generar las migraciones (usando el ORM de Django)
- Cargar la información a tu base de datos
Para eso recomendamos primero tener una sola "app" para controlar todo lo
relacionado a la administración de taxis y dentro de la app crear dos modelos,
uno para almacenar la información de taxis (taxis
) y otro para almacenar la
información de ubicaciones (trajectories
).
Deberás definir los campos de cada modelo de acuerdo a la información entregada. Al momento de querer cargar la información es necesario que modifiques el script para especificar en que app trabajaran las 2 tablas hemos preparado el siguiente.
Ejemplo de la modificación:
-- Así se visualiza originalmente una linea en el script
INSERT INTO trajectories (id, date, latitude, longitude ) VALUES ('10133','2008-02-02 13:47:59',116.37659,39.85567);
Agregando el nombre de la app (en este ejemplo nombramos el app taxiapp
):
-- Así se visualiza con el nombre de la tabla cambiado
INSERT INTO taxiapp_trajectories (id, date, latitude, longitude ) VALUES ('10133','2008-02-02 13:47:59',116.37659,39.85567);
Puede realizar este cambio fácilmente con la función de buscar y reemplazar (find and replace), para todas las apariciones en scripts SQL.
También, hay un video para ejemplificar como agregar el app en el script.
Con Django es posible integrar herramientas como Django rest framework para trabajar la creación de una API y su documentación oficial es clave para guiarte en la instalación y uso de la herramienta.
Al momento en que empieces a documentar los endpoints de tu API. Debes usar Swagger para rest framework