Modulo Programacion - Proyecto Integrador - Grupo 24 - Propuesta: Desarrollo de un Sistema de Gestión para un Taller Mecánico.
Nombre: Daniel
Apellido: Villalba
DNI: 26.368.675
Email: dandrovil.dv@gmail.com
Github: https://github.com/dandrovil
Nombre: Nahir
Apellido: Zucaria
DNI: 40.739.637
Email: nahirzucaria@gmail.com
Github: https://github.com/NZucaria
Nombre: Adriel
Apellido: Delosanto
DNI: 36.876.897
Email: adridelosanto@gmail.com
Github: https://github.com/adriel1364
Nombre: Dalmiro
Apellido: Vilca
DNI: 40.403.978
Email: dalmirovilca@gmail.com
Github: https://github.com/dalmiro
Nombre: Eglimar
Apellido: Ramirez
DNI: 96.062.692
Email: eglimarmramirez@gmail.com
Github: https://github.com/EglimarRamirez
El proyecto se realiza integrando los temas abordados en el "módulo de programador" del primer semestre del ISPC. Este abarca las materias Ética y Deontología Profesional, Base de Datos e Introducción a la Programación.
Se trata de un sistema de gestión que desarrolla una solución integral para optimizar la operación diaria de un taller mecánico, facilitando la administración de clientes, vehículos, órdenes de trabajo, inventarios y facturación.
Este sistema tiene como objetivo mejorar la eficiencia operativa, reducir errores administrativos y proporcionar una mejor experiencia tanto para los empleados del taller como para los clientes. Mientras qué a nivel académico busca plasmar los conocimientos adquiridos en las distintas materias durante el cursado del espacio curricular.
- Registro de Clientes y Vehículos: Permite agregar, modificar y eliminar clientes y sus vehículos.
- Gestión de Órdenes de Trabajo: Crea, visualiza y actualiza órdenes de trabajo. Cambia el estado de las órdenes cuando se completan.
- Generación de Facturas: Crea y visualiza facturas para los servicios prestados a los clientes.
- Control de stock: Permite tener un seguimiento e inventario del stock de repuestos.
- Eficiencia Operativa: Reduce el tiempo y los errores asociados con la gestión manual de información.
- Mejor Servicio al Cliente: Proporciona información precisa y rápida a los clientes sobre sus vehículos y trabajos realizados.
- Transparencia y Trazabilidad: Facilita el seguimiento de las órdenes de trabajo y las responsabilidades de cada mecánico.
- Automatización de Facturación: Asegura la generación precisa y rápida de facturas, mejorando el flujo de caja del taller.
- Control permanente de stock: Asegura contar con repuestos necesarios y llevar un inventario de los mismos para brindar el servicio en un tiempo acorde y eficiente.
En el menú principal del programa se mostrarán opciones para interactuar con las diferentes funcionalidades de cada módulo.
Al elegir alguno de estos módulos se darán las opciones de crear, eliminar, actualizar o mostrar instancias de una entidad, según el módulo qué se seleccione.
Una vez seleccionado un módulo se deberá elegir a continuación qué acción se desea realizar ( crear, eliminar, actualizar o mostrar) y luego se deberá ingresar los datos solicitados por el programa.
El resultado se mostrará en terminal de acuerdo a las opciones elegidas.
NOTA: Revisar el archivo Video del repositorio para información adicional.
Para utilizar el programa se deberá instalar lo siguiente:
- SQL y MySQL Workbench- Se recomienda desde la web MySQL Installer
- SQL Connector - Desde la terminal usar el comando pip install mysqlx-connector-python.
- Pandas - Desde la terminal usar el comando pip install pandas.
- Tabulate - Desde la terminal usar el comando pip install tabulate.
-
Main_V2.py: Es el archivo qué contiene el código del menú principal del programa, desde el cuál se accede mediante input del usuario a las diferentes funciones (CRUD) de cada módulo.
-
mecanicos.py: Archivo con el CRUD del módulo MECÁNICOS.
- Función agregar():Función para crear un nuevo mecánico en la base de datos.
- Función agregar():Función para crear un nuevo mecánico en la base de datos.
- Función actualizar(): Función para actualizar datos de un mecánico en la base de datos.
- Función buscar(): Función para buscar un mecánico en la base de datos.
- Función eliminar(): Funcion para eliminar un mecánico en la base de datos.
- Función mostrar(): Funcion para mostrar todos los mecánicos en la base de datos.
-
presupuestos.py: Archivo con el CRUD del módulo presupuesto.
- Función crear(): Agrega un nuevo presupuesto a la base de datos.
- Función actualizar(): Actualiza los datos de un presupuesto existente en la base de datos.
- Funcion buscar(): Funcion para buscar un presupuesto por "idorden" en la base de datos.
- Función mostrar(): Muestra todos los presupuestos que existen en la base de datos.
- Función consultar(): Buscar un presupuesto por "idpresupuesto".
-
stock.py: Archivo con el CRUD del módulo stock.
- Función agregar():Agrega nuevos items al inventario.
- Función actualizar(): Actualiza los datos de un ıtem existente en el inventario.
- Función eliminar(): Elimina un ´ıtem del inventario.
- Función mostrar(): Muestra todos los ıtems almacenados en el inventario.
- Función buscar(): Buscar ítem en el inventario por "idstock".
-
clientes.py: Archivo con el CRUD del módulo clientes.
- Función agregar(): Agrega un nuevo cliente a la base de datos.
- Función actualizar(): Actualiza los datos de un cliente existente en la base de datos.
- Funcion buscar(): Funcion para buscar un cliente en la base de datos.
- Función eliminar(): Elimina un cliente de la base de datos.
- Función mostrar(): Funcion para mostrar todos los clientes en la base de datos.
-
vehiculos.py: Archivo con el CRUD del módulo vehículos.
- Función agregar(): Agrega un nuevo vehículo a la base de datos.
- Función actualizar(): Actualiza los datos de un vehículo existente en la base de datos.
- Función buscar_patente(): Función para buscar un vehiculo por patente en la base de datos.
- Función buscar_propietario(): Función para buscar un vehículo por "id_Cliente" en la base de datos.
- Función mostrar(): Funcion para mostrar todos los vehículos en la base de datos.
- Funcion consultar(): Funcion para consultar si existe un vehículo en la base de datos.
- Función eliminar(): Elimina un vehículo de la base de datos.
-
ot.py: Archivo con el CRUD del módulo ORDENES.
- Función crear(): La función crear() permite registrar una nueva orden de trabajo para un vehículo específico en una base de datos solicitando la patente del vehículo y el motivo de la avería, y luego almacenando esta información junto con la fecha actual en la tabla ordenes.
- Función consultar(): La función consultar(id) busca y muestra todas las órdenes de trabajo que tienen un estado específico (id) en la base de datos formateando y mostrando los detalles relevantes de cada orden si se encuentran.
- Función asignar(): la función asignar() facilita la asignación de una orden de trabajo a un mecánico específico en la base de datos verificando la existencia de la orden y del mecánico antes de realizar la asignación.
- Función mostrar_ordenes(): La función mostrar_ordenes() realiza una consulta a la base de datos para recuperar todas las órdenes almacenadas y las muestra en la consola. Si no hay órdenes disponibles, informa al usuario de esta situación.
- Función buscar(): la función buscar(id) permite verificar la existencia de una orden específica en la base de datos a través de su idOrden devolviendo True si la orden existe y False si no existe.
- Función update(): La función update(id, status) permite modificar el estado de una orden específica en la base de datos.
-
sql: Archivo qué contiene el código necesario para establecer la conexión, desconexión y realizar consultas con la base de datos.
- CROWFOOT.jpeg: Archivo en formato jpeg con el diagrama de la base de datos en notación Crowfoot.
- Notación de CHEN.jpeg: Archivo en formato jpeg con el diagrama de la base de datos en notación de CHEN.
- taller.mwb: Archivo en formato mwb con el Crowfoot de la base de datos.
- taller.sql: Archivo en formato sql qué contiene el script para crear las tablas y sus respectivos datos en la base de datos.
- Diagrama de flujo.png: Archivo en formato png qué contiene el diagrama de flujo de la aplicación.
- EPS.txt: Un archivo en formato txt qué contiene el análisis EPS (Entrada, Proceso, Salida) del programa.
- Sistema-Taller.psc: Archivo en formato psc qué contiene el pseudocódigo del menú principal del programa.
- .gitignore: Archivo de configuración en el cuál se especifica qué archivos se van a ignorar al hacer un push. Por ej. dependencias, archivos de configuración de VSC, etc.
- Análisis.txt: Archivo en formato txt qué contiene el análisis de funcionamiento del programa.
- README.md: Archivo en formato markdown qué contiene principalmente información sobre el contenido del repositorio, el funcionamiento general del programa y cómo utilizarlo.
- Video: Video explicativo del uso de la aplicación, con casos de uso y ejemplos.