Mostrando entradas con la etiqueta Python. Mostrar todas las entradas
Mostrando entradas con la etiqueta Python. Mostrar todas las entradas

viernes, 28 de febrero de 2025

[Python + Tkinter] Fast Music 1.0

En este proyecto se hizo un completo reproductor de música en Python usando ttkbootstrap para la interfaz gráfica, usa Sqlalchemy para trabajar con una base de datos Sqlite que gestiona la configuración y manejo de multimedia del programa.

Las funciones incorporadas son :

* Reproducción de música, videos y streams.
* Sincronización de toda la muisca usando Google Drive.
* Se pueden descargar uno o varios videos de youtube para convertir en MP3 o MP4 según se necesite.
* Permite descargar playlists completas de youtube y convertir en música o videos.
* El reproductor registra en la base de datos las ultimas playlists seleccionadas para cargarlas siempre al inicio de la aplicación.  

A continuación se muestran unas imágenes del programa en funcionamiento.

 






 

Para instalar las dependencias se necesita ejecutar el siguiente comando :

pip install -r requirements.txt

Ademas se tienen que crear las credenciales para el servicio "Google Drive API" en la URL https://console.cloud.google.com, una vez creado todo se descargan las credenciales y se guardan en el mismo directorio del programa con el nombre de client_secrets.json.

Una vez configurado todo, se puede ejecutar la aplicación app.py para iniciar el programa, cuando se inicie se debe cargar la ventana "Configuración" y configurar todos los directorios que se necesitan para escanear las canciones y videos, también es necesario especificar el directorio donde están guardadas las canciones en Google Drive y se deben configurar los directorios donde se van almacenar las canciones descargadas. Cuando todos esos datos estén configurados se podrá iniciar el escáner desde ese misma ventana y reproducir cualquier archivo multimedia que se necesite.

 

 Github

jueves, 31 de octubre de 2024

[Flask] Quick Launcher 1.0

En este proyecto se hizo un sistema para lanzar procesos en segundo plano que usa Flask con Bootstrap 5, usando MySQL para gestionar los datos de la aplicación. Esta pensando para gestionar servidores y facilitar los manejos de los comandos de cada uno, ya sean de proyectos de Laravel, NodeJS, Angular, React o cualquier otro. También incluye una función para que ejecute en el navegador la URL del proceso ejecutado después de un tiempo de espera asignado en el sistema.

Las funciones incorporadas son :

Inicio de sesión obligatorio para usar el sistema protegido con JWT.

Posibilidad de cambiar usuario y contraseña.

Posibilidad de cambiar el theme completo del sistema a un modo oscuro o claro.

Se puede agregar, editar y borrar procesos. En la sección de procesos se pueden gestionar las tareas de cada proceso.

En la página principal se listan todas los procesos registrados donde se pueden ejecutar y detener las tareas de cada uno. También hay una sección de logs donde se muestran los procesos activos con sus PID asociados y se pueden cerrar por tarea o por proceso.

A continuación se muestran unas imágenes del sistema en funcionamiento.







 


Para la correcta instalación del sistema se deben seguir los siguiente pasos.

En la carpeta principal se debe renombrar el archivo .env.example a solo .env y editar la configuración con los datos de tu conexión MySQL, el SECRET_KEY que seria la clave para generar el JWT.

Para instalar la librería de conexión a MySQL en Linux el comando debería ser :

sudo apt-get install python3-pymysql

De lo contrario si están usando Windows seria :

pip install PyMySQL

Posteriormente debemos terminar de instalar las dependencias con el siguiente comando :

pip install -r requirements.txt

Para ejecutar Flask en Windows se debe hacer de la siguiente manera :

python -m flask

De lo contrario si están usando Linux bastaría con usar simplemente el comando flask, teniendo en cuenta esto para ejecutar las migraciones de Flask deben ejecutar los siguientes comandos :

flask db init

flask db migrate

flask db upgrade

flask seed


Finalmente para iniciar el sistema se debe ejecutar este comando :

flask --app main.py --debug run --port=8888

 

Github




miércoles, 16 de octubre de 2024

[Django + Angular] Fast Music 1.0

En este proyecto se hizo un completo reproductor de música, las tecnologías que usa son Django como Backend y Angular como Frontend, la base de datos que usa es MySQL.

Las funciones incorporadas son :

Inicio de sesión obligatorio para usar el sistema protegido con JWT.

Posibilidad de cambiar usuario y contraseña.

Posibilidad de cambiar el theme completo del sistema a un modo oscuro o claro.

Se puede sincronizar una carpeta de Google Drive con la carpeta local del sistema donde se guardara toda la música, también se puede hacer el efecto contrario, que seria sincronizar la carpeta local del sistema con la carpeta de Google Drive.

Incorpora un escaneo de carpeta local donde se deben registrar todas las canciones guardadas cada una en su playlist o carpeta correspondiente.

En el reproductor de música se puede filtrar por playlists que serán guardadas en Redux, lo mismo seria para filtrar por nombre de canción. Ademas se pueden fijar canciones como favoritas lo que hará que se cree una playlist aparte al principio de la lista para poder localizar de una forma mas eficiente.

También incorpora un reproductor de estaciones o streams, en esa sección se pueden registrar, editar y borrar estaciones, para mayor comodidad incorpora un buscador por nombre que usa Redux. Ademas contiene las funciones de importar las estaciones en formato json, exportar las estaciones para descargar en formato json y la función de validar todas las estaciones para verificar su correcto funcionamiento y borrarlas en caso de no estén funcionando.

A continuación se muestran unas imágenes del sistema en funcionamiento.


 

Para la correcta instalación del sistema se deben seguir los siguiente pasos.

En la carpeta del Backend que sería "sistemaApi" se debe renombrar el archivo .env.example a solo .env y editar la configuración con los datos de tu conexión MySQL. También se debe editar el SECRET_KEY con tu propia clave, se puede generar una con el siguiente comando :

python3 -c 'from django.core.management.utils import get_random_secret_key; print(get_random_secret_key())'

Después se tienen que crear las credenciales para el servicio "Google Drive API" en la URL https://console.cloud.google.com, una vez creado todo se descargan las credenciales y se guardan en el mismo directorio del archivo manage.py con el nombre de client_secrets.json.

Una vez terminado todo se deben seguir estos pasos :

Para instalar las dependencias de Django :

pip install django djangorestframework djangorestframework_simplejwt

sudo apt install pkg-config

sudo apt-get install gcc libmysqlclient-dev python3-dev

pip install mysqlclient

pip install django-cors-headers

pip install python-dotenv


Para instalar el modulo necesario para sincronizar con Google Drive :

pip install PyDrive

Para realizar las migraciones de Django :

python3 manage.py makemigrations

python3 manage.py migrate


Para crear el usuario por defecto :

python3 manage.py createsuperuser

Finalmente para iniciar el servidor se debe ejecutar este comando :

python3 manage.py runserver 7777

En la carpeta del Frontend que sería "sistemaFrontend" se debe ejecutar el siguiente comando para instalar las dependencias :

npm install

En esa misma carpeta deben ir al directorio "environments" para modificar los archivos environment.ts reemplazando las variables "apiUrl" y "filesUrl" por la ruta de su servidor Backend.

Finalmente para iniciar el servidor se debe ejecutar este comando :

npm run start


Github



domingo, 2 de junio de 2024

Video Manager 1.0

Este proyecto seria un script hecho en Python con una versión GUI aparte con las opciones mas importantes. La mayoría de las funciones están orientadas a videos de YouTube.

En el caso del script, los comandos para su uso serian : 

-download-video : Se pide como argumento el link del video para descargar en formato en MP4, se puede combinar con -output-name.

-download-song : Se pide como argumento el link el video para descargar en formato MP3, se puede combinar con -output-name.

-download-videos : Se pide como argumento un archivo con una lista de links para descargar los videos en formato MP4.

-download-songs : Se pide como argumento un archivo con una lista de links para descargar en formato MP3.

-convert-to-mp3 : Se pide como argumento la ubicación local de un video para convertirlo en MP3, se debe combinar con -output-name para guardar la canción.

-findsong-and-download : Se pide como argumento el nombre de la canción para buscar en Google y posteriormente descargar en formato MP3.

-findsongs-and-download : Se pide como argumento un archivo con una lista de nombres para buscar en Google y descargar en formato MP3.

-read-playlist : Se pide como argumento el link de la playlist para listar los links correspondientes, se debe combinar con el comando -output-name para fijar el nombre del archivo en el que se guardara los resultados.

-download-playlist-videos : Se pide como argumento el link de la playlist para descargar todos los videos en formato MP4.

-download-playlist-songs : Se pide como argumento el link de la playlist para descargar todos los videos en formato en MP3.

-output-name : Se pide como argumento el nombre con el que se guardara el archivo, tiene que ser solo el nombre, sin extensión.

-output-folder : Se pide como argumento el nombre de la carpeta en el que se guardara, si no existe, la crea, esta opción se puede combinar con todas las funciones en el que se descargan videos o canciones.

En la versión GUI solo se permite descargar videos y canciones con la opción de elegir nombre y carpeta. Ademas al iniciar detectara si en el portapapeles hay un link válido para insertarlo directamente en el textbox de Link.

El proyecto fue pensado para usar en Windows por lo que todas las descargas se guardaran en las carpetas "Música" y "Vídeos", la subcarpeta se llamara "Video_downloads", el script mismo detectara si es una canción o un video y lo guardara en su correspondiente carpeta.

Unas imágenes de ejemplo de uso para cada versión : 





Github

domingo, 10 de septiembre de 2023

Generador de tutoriales 1.1

Un programa hecho en Django con VueJS para generar tutoriales para canciones de guitarra, primero se crea un nuevo tutorial, para después ir a la sección de capturas, cargar el video y realizar capturas de imagen con descripción que se irán guardando, las capturas se pueden editar, ordenar y borrar. Una vez hecho este proceso se va a la sección de generar y se mostraran las imágenes con las descripciones ordenadas en una galería que permite mostrar las imágenes con las aclaraciones de cada una.

El proyecto ha sido actualizado a su version 1.1 y ahora puede buscar por título ademas de filtrar por dificultad y genéro. Tambien puede mostrar estadísticas que muestran cuantos tutoriales hay por dificultad y genéro.

Si ejecutan el proyecto por primera vez deben crear la base de datos SQLite con los siguientes comandos : 

manage.py makemigrations

manage.py migrate 

Para ejecutar el proyecto se debe usar el comando : 

manage.py runserver 9999

Unas imágenes :






Github

sábado, 20 de mayo de 2023

Generador de tutoriales 1.0

Un programa hecho en Django con VueJS para generar tutoriales para canciones de guitarra, primero se crea un nuevo tutorial, para después ir a la sección de capturas, cargar el video y realizar capturas de imagen con descripción que se irán guardando, las capturas se pueden editar, ordenar y borrar. Una vez hecho este proceso se va a la sección de generar y se mostraran las imágenes con las descripciones ordenadas en una galería que permite mostrar las imágenes con las aclaraciones de cada una.

Para ejecutar el proyecto se debe usar el comando "manage.py runserver 9999".

Unas imágenes : 






Github

martes, 17 de agosto de 2021

martes, 1 de septiembre de 2020

Radio Online 1.0

 Es una aplicación en Django para gestionar emisoras de radios. En la cual se pueden dividir por categorias como Rock o Electronica. Se pueden crear, editar y borrar categorias y emisoras. La aplicación ya viene con una base de datos con emisoras de cada categoria. Además cuenta con un reproductor de las emisoras para controlar la reproducción de las mismas.

Unas imágenes : 



 

 Github

miércoles, 27 de mayo de 2020

Directory Cleaner 0.3

Un script en Python para limpiar un directorio. Las extensiones soportadas son : zip, rar, avi, mp4, mkv, srt, ico, bmp, jpg, jpeg, png, gif, txt, pdf, exe, docx, html.

La mayoria de los archivos se mueven a la carpeta documentos con directorios creados con el nombre de la extension, los mp3 a la carpeta música y los videos a la carpeta de videos.

El script tiene dos comandos :

-clean <directorio>  : Limpia el directorio seleccionado
-clean-downloads : Limpia la carpeta de descargas

El script lo pueden encontrar en el siguiente link de github. 

lunes, 11 de mayo de 2020

Youtube Manager 1.0

Un programa en Python para descargar música y videos de Youtube.

Los comandos son  :

-download-video : Ingrese el link del video para descargarlo en MP4

-download-videos : Ingrese un archivo con una lista con varios links de videos para descargarlos en MP4

-download-mp3 : Ingrese el link del video para descargarlo y convertirlo a MP3

-findsong-and-download : Ingrese el nombre de la canción para buscar en google y poder descargar el video para convertirlo a MP3

-findsongs-and-download : Ingrese archivo con una lista con los nombres de las canciones que quiere descargar y convertir en MP3

-download-links-song : Ingrese un archivo con una lista de links de videos para descargar y convertir a MP3

-download-playlist : Ingrese el link de una playlist para descargar y convertir a MP3

-download-playlists : Ingrese un archivo con una lista de playlists para descargar y convertir a MP3


miércoles, 22 de abril de 2020

Fenix PC Locker 0.3

Un script en Python para bloquear el sistema a intrusos cuando el administrador no esta, si el hotkey o combinación de teclas no es pulsado al volver al sistema, automaticamente se suspende Windows.
El hotkey funciona con Control + Shift + Tecla personal, ademas guarda en un log la hora en que se bloqueo para saber el momento en que alguien quizo usar nuestro sistema sin nuestra autorización.



domingo, 18 de agosto de 2019

Wallpaper Manager 1.0

Es una aplicación en Django que permite gestionar wallpapers en su base de datos.

Funciones :

- Se pueden agregar, editar y borrar wallpapers en la aplicación Django.
- También se pueden ordenar por el tipo de estacion (Verano, Otoño, Invierno y Primavera) y momento del dia (Amanacer, Mañana, Tarde y Noche) .
- Incluye un script secundario "loop.pyw", que funciona en segundo plano y se actualiza cada 1 hora para ir cambiando los wallpapers dependiendo de la estacion o momento del día
- Incluye un atajo de teclado que es "Control izquierdo + Shift + a" para ir cambiando los wallpapers manualmente.

Una captura :






El proyecto se encuentra en mi github.

Radio Online 0.1

Es una aplicación en Django para gestionar emisoras de radios. En la cual se pueden dividir por categorias como Rock o Electronica.
Se pueden crear, editar y borrar categorias y emisoras. La aplicación ya viene con una base de datos con emisoras de cada categoria.

Una captura :



El proyecto esta publicado en mi github

sábado, 17 de febrero de 2018

Agenda Fénix 1.1

Este proyecto es una agenda que hice en Python-Django que guarda todo en una base de datos SQLite.

Funciones :

* Registro de usuario
* Ingreso de usuario
* Agregar, editar, borrar y visualizar : categorias, notas, proyectos y actividadesSe permite insertar etiquetas html en los contenidos de las notas, proyectos y actividades
* Alarma con sonido
* Importar y exportar datos
* Muestra gráfico estadístico de cantidad de notas por categoria
* Cambiar usuario y clave de la cuenta
* Se agrego dos skins de diseño para la agenda

Cuando se importan datos se necesita seguir los siguientes pasos ...

Crear las carpetas "Actividades", "Notas" y "Proyectos".

En actividades se necesita crear un archivo de texto por cada actividad de la siguiente forma :

[+] Fecha : 2017-12-05
[+] Hora : 22:05:00
[+] Terminado : 0

Contenido de actividad


En las notas se debe crear una carpeta por cada categoria que quieran usar y por cada nota crear un archivo de texto con el título y contenido que quieran,

En los proyectos se debe crear un archivo de texto por cada proyecto de la siguiente forma :

[+] Fecha inicio : 2015-08-06
[+] Fecha terminado : 2018-09-10
[+] Terminado : 1

Contenido de proyecto


Algo a tener en cuenta es el título del archivo de texto siempre sera el título de cualquiera de las tres publicaciones.

También incluye un instalador del proyecto y launcher que evita usar manage.py para iniciar el proyecto además de hacer una copia de respaldo de la base de datos sqlite.

La versión de django que use es : 1.11.1

Imágenes :








Despues de la actualizacion 1.1, la agende se ve asi :






Links :

[Laravel + ReactJS] Agenda Fénix

Este proyecto es una agenda full-stack que usa Laravel para el backend y ReactJS con Vite , Material UI y Redux para el frontend, con My...