Python script for download course from platzi.com

Overview

Platzi Downloader Tool

Platzi Downloader Tool Preview Esta es una pequeña herramienta que hace mucho y que te ahorra una gran cantidad de trabajo a la hora de descargar cursos de Platzi

Instalaciones necesarias

De momento solo se da referencia a la instalación en Sistemas GNU/Linux como Debian GNU/Linux, Ubuntu, ArchLinux

  • python 3.x.x

    Instalación en Debian GNU/Linux o Ubuntu

    Ejecuta: sudo apt-get install python3

    Instalación en ArchLinux y Manjaro

    Ejecuta: sudo pacman -S python

    Instalación en otros sistemas operativos o distribuciones

    Ingresa al Sitio Oficial de Python

    Puedes ver esta guia para Windows

  • pip

    Instalación en Debian GNU/Linux o Ubuntu

    Ejecuta: sudo apt-get install python3-pip

    Instalación en ArchLinux y Manjaro

    Ejecuta: sudo pacman -S python-pip

    Para otros sistemas operativos o distribuciones de GNU/Linux busca en Internet

    Puedes revisar esta guia para Windows

  • youtube-dl

    Instalación en Debian GNU/Linux o Ubuntu

    Ejecuta: sudo apt-get install youtube-dl

    Instalación en ArchLinux y Manjaro

    Ejecuta: sudo pacman -S youtuble-dl

    Instalación en otros sistemas o plataformas

    Ingresa al sitio oficial de youtube-dl para más información sobre instalaciones.

    Si realizas la instalación en Windows asegurarte de agregar el programa a la variable PATH, de este modo no se generaran problemas.

    Para no tener problemas de dependencias es recomendable instalar la dependencia python-pycryptodome

  • ffmpeg

    Instalación en Debian GNU/Linux o Ubuntu

    Ejecuta: sudo apt-get install ffmpeg

    Instalación en ArchLinux y Manjaro

    Ejecuta: sudo pacman -S ffmpeg



    Tip: Si algo falla al momento de la instalación prueba actualizar los repositorios de tu distro

Instalación de módulos python necesarios

Los pasos de instalación que se muestran son probados solo en sistemas GNU/Linux no es seguro que funcionen si tiene un sistema operativo diferente como Windows.

  • requests

    Ejecuta: pip3 install requests

  • lxml

    Ejecuta pip3 install lxml

  • colorama

    Ejecuta pip3 install colorama

Si al momento de la descarga te da un error prueba verifica si los módulos json y re están correctamente instalados.

Importante (WSL)

Debido a que el programa esta probado solo en distribuciones basadas en GNU/Linux, no se espera que funcione en Windows aunque se hagan las instalaciónes correctamente. Para usar el programa en Windows recomiendo usar WSL (Windows Subsystem For Linux).

Extra: Para una guia básica de la instalación en WSL puedes echar un vistaso aquí

Modo de empleo

Clic para abrir el video alt text

Notas:
El archivo cookies.txt debe guardarse en la carpeta donde se encuentra el scipt platzi-dtool.py para que el programa no genere errores.

Debido a que no tengo una suscripción en platzi no puede comprobar si el modo de descarga masiva de cursos funciona correctamente, si hay algún error estén atentos que tan pronto comienza el platzi day se corregirán lo antes posible.

Recomiendo que no descarguen los cursos en la carpeta donde se encuentra el programa y el resto de archivos, creen una nueva carpeta limpia para que no tengan problema alguno.

IMPORTANTE: Recomiendo que descarguen varios cursos a la vez, de ese modo puede aprovechar el maximo de la velocidad de descarga que brinde vuestra red.

Estructura de los directorios usados

Aquí una breve explicación de los directorios que se crearan y usaran para guardar los cursos descargados.

  • Descargando una ruta de aprendizaje o escuela

    Cuando se realizan este tipo de descargas se genera la siguiente estructura de directorios:

      Convensiones usadas:
          [CN] = Digitos que se usan para numerar los cursos para que queden ordenados
    
          [COURSE_NAME] = Nombre del curso.
    
          [SN] = Numero de seccion, digito que permite ordenar una seccion
    
          [SECTION_NAME] = Se refiere al nombre de la sección dentro del curso
    
          [LN] = Numero que identifica a una leccion dentro de una seccion
    
          [LESSON_NAME] = Nombre de la leccion
    

    Jerarquía de directorios

    El número uno en la jerarquía es la carpeta del curso, la cual se nombre de la siguiente manera:

      [CN] - [COURSE_NAME]
    

    Esto se hace para que se puedan ordenar y saber cual curso es él siguiente cuando se descargan rutas o escuelas de aprendizaje.

    Dentro de la carpeta del curso encontramos lo siguiente

      [CN] - [COURSE_NAME]
          [SN] - [SECTION_NAME]
    

    La estructura anterior hace referencia una sección dentro de un curso. Las secciones van enumeradas para que se pueda saber que sección es primero y cual es última.

    La siguiente estructura es:

      [CN] - [COURSE_NAME]
          [SN] - [SECTION_NAME]
              [LN] - [LESSON_NAME]
    

    La estructura anterior hace referencia a una lección que se encuentra contenida dentro de una sección la cual a su vez está contenida dentro de un curso.

    Las lecciones se enumeran para que se puedan ordenar y se pueda saber con cual continuar, el nombre de la lección en algunos casos no puede ser exacto, ya que algunos caracteres se reemplazan por otros o se eliminan para tener mayor compatibilidad un ejemplo es el caso del carácter :, que se reemplaza por la cadena - (espacio + -).

    La siguiente estructura se usa para almacenar la página de la lección, ya que en algunos casos esta contiene información como enlaces a otros recursos o resúmenes de la lección.

      [CN] - [COURSE_NAME]
          [SN] - [SECTION_NAME]
              [LN] - [LESSON_NAME]
              [LN] - extra_files
    

    Ya que algunas lecciones no son videos, se descargara la página web, la cual contiene el contenido de la lección tal como esta y se puede ver de forma offline, aunque se requiere conexión a Internet para cargar imagines.

    Cuando se descarga una lección de video, se descargara una página web, la cual es la página que se encuentra en la url de la clase, dicha página tiene el siguiente nombre.

      Estando en:
          [LN] - extra_files
              [LN] - webpage.html
    

    Otro archivo que se encontrará es un archivo llamado 000 - Preview.html, este archivo se encuentra en la carpeta del curso, y se trata de la página del curso, la puedes usar para saber cierta información del curs y también para saber como se estructura el curso aunque no haga falta.

  • Descargando un solo curso

    Cuando en el archivo que contiene la información de la descarga solo hay un curso la carpeta de este curso no contiene una numeración solamente el nombre.

      [COURSE_NAME]
          [SN] - [SECTION_NAME]
              [LN] - [LESSON_NAME]
              [LN] - extra_files
    

    De tal modo la estructura del curso será como la siguiente.

Con eso se concluye la explicación de los directorios usados por las descargas.

Recomendaciones de uso

  • Sistema operativo

    Este programa fue probado en ArchLinux, pero puedo sugerir que se ejecutara sin problemas en cualquier otra distribución de Linux siempre que se tengan los programas y los módulos de python correctamente instalados.

    Puedes probar en Windows aunque no estoy muy seguro de que funcione bien, debido a que usa un sistema de archivos diferente a los sistemas de archivos Unix.
    Si lo probaste y ocurrió algún error puedes abrir una discusión y poner la salida de la ejecución de ese modo podre arreglarlo rápidamente y dar soporte a usuarios de Windows

  • Descargando

    Si la descarga se pausa y no avanza más presiona CTL + C solo una vez, de este modo la descarga volverá a iniciarse y retomar desde el punto en el que encontraba.

    Puedes usar CTL + C tantas veces que quieras pero solo si se está descargando un video sabras que se está descargando cuando ves un texto que dice "Status: Downloading video" or algo similar.

    En carro de que la descarga se interrumpa, esta volverá a reiniciarse hasta que se haya descargado por completo, así que no tendrás problemas con esto.

Solución de problemas

Si te genera un problema al momento de correr el programa abre el archivo utils/text_utils.py y en la línea 6 deberás ver algo como esto: TERMINAL_COLUMNS = os.get_terminal_size().columns cambia su valor a 80 o un número cercano a este.

Si estas en Windows y experimentas problemas con la creación y guardado de archivos, puedes abrir una discusión y pones la salida del error, de ese modo me ayudaras a arreglar el error rápidamente.

Información extra

Las herramientas usadas en el programa no son de mi propiedad, son herramientas de código libre que llevan años funcionando aquí la lista de los programas que he usado:

Si te gusto el programa puedes darle una estrella.
Si tienes alguna idea de como mejorar el programa, puedes abrir una discusión y comentar, tal vez se pueda hacer algo.

Esta herramienta la cree debido a que mi conexión a Internet es realmente mala y solo está algo decente en horas de la noche, en las cuales ya no es posible aprovecharla debido al cansancio o al sueño.
Me gusta mucho aprender pero trasnochar todos los días no es bueno para el cuerpo y la mente, por eso me dije y si descargo las clases mientras duermo?, y así se creó este en 7 Dias xD

Ente proyectó no se hizo con intensiones de Piratería, ya que es solo una herramienta para las personas que no pueden cuentan con una conexión a Internet estable y de este modo pueden descargar las clases y verlas cuando quieran con más comodidad.

Owner
Devil64-Dev
Junior web developer, who wants to learn more about new technology every day.
Devil64-Dev
This repository contains the best Data Science free hand-picked resources to equip you with all the industry-driven skills and interview preparation kit.

Best Data Science Resources Hey, Data Enthusiasts out there! Finally, after lots of requests from the community I finally came up with the best free D

Mohit Kumar 415 Dec 31, 2022
WaifuGen - A program made in waifuGen that generates SFW and NSFW waifus from the waifu.pics API

waifuGen A program made in waifuGen that generates SFW and NSFW waifus from the

1 Jan 05, 2022
Live Weather Updates using Flask and OpenWeather

AuraX Live Weather Updates using Flask and OpenWeather Installation To setup this project on your local machine, first clone this repository and insta

Ayush Gupta 3 Nov 02, 2021
Discord bot for polls and votes including STV. Supports hiding results and is written with Discord.py

VoteBot Discord voting bot capable of standard polls, as found in many other bots; anonymous polls, where votes are hidden and totals are only display

6 Nov 15, 2022
Ap lokit lokit

🎵 FANDA PROJECT 🎵 HAI AKU FANDA! Requirements 📝 FFmpeg NodeJS nodesource.com Python 3.8 or higher PyTgCalls MongoDB Get STRING_SESSION from below:

Fatur 2 Nov 18, 2021
Track player's stats, find out when they're online and grinding!

Hypixel Stats Tracker Track player's stats, find out when they're online and playing games! INFO Showcase Server: https://discord.gg/yY5qQHPar6 Suppor

4 Dec 18, 2022
Autofilter with imdb bot || broakcast , imdb poster and imdb rating

LuciferMoringstar_Robot How To Deploy Video Subscribe YouTube Channel Added Features Imdb posters for autofilter. Imdb rating for autofilter. Custom c

Muhammed 127 Dec 29, 2022
Monetize your apps with KivAds using Google AdMob api.

KivAds(WIP) Monetize your apps with KivAds using Google AdMob api. KivAds uses the latest version of Google AdMob sdk(version 20.0.0). KivAds exposes

Guhan Sensam 16 Nov 05, 2022
An advanced QR Code telegram bot with more features.

QR Code Bot A telegram qr code encode and decode bot Advanced Features 1. Database ( MongoDB ) Support 2. Broadcast Support 3. Status Command 4. Setti

Fayas Noushad 16 Nov 12, 2022
Automatic generation of crypto-arts based on image layers

NFT Generator Автоматическая генерация крипто-артов на основе слоев изображения. Установка pip3 install -r requirements.txt rm -rf result/* Как это ра

Zproger 31 Dec 29, 2022
Telegram chats reader with python

Telegram chat reader Программа полностью сливает чаты телеграм в базу данных PostgreSQL. Для использования нужен развернутый сервер постгрес и телегра

Anton 4 Dec 24, 2021
A basic API to scrape Craigslist.

CLAPI A basic API to scrape Craigslist. Most useful for viewing posts across a broad geographic area or for viewing posts within a specific timeframe.

45 Jan 05, 2023
RChecker - Checker for minecraft servers

🔎 RChecker v1.0 Checker for Minecraft Servers 💻 Supported operating systems: ✅

Pedro Vega 1 Aug 30, 2022
Telegram Bot to store Posts and Documents and it can Access by Special Links.

Telegram Bot to store Posts and Documents and it can Access by Special Links. I Guess This Will Be Usefull For Many People..... 😇 . Features Fully cu

REX BOTZ 1 Dec 23, 2021
An unofficial python wrapper for the comdirect API for private consumers.

An unofficial python wrapper for the comdirect API for private consumers.

Alexander Knittel 18 Nov 30, 2022
Automatic SystemVerilog linting in github actions with the help of Verible

Verible Lint Action Usage See action.yml This is a GitHub Action used to lint Verilog and SystemVerilog source files and comment erroneous lines of co

CHIPS Alliance 10 Dec 26, 2022
A modular Telegram Python bot running on python3 with a sqlalchemy, redislab, mongo database, telethon, and pyrogram.

Zeldris Robot A modular Telegram Python bot running on python3 with a sqlalchemy, redislab, mongo database, telethon, and pyrogram. How to set up/depl

IDNCoderX 42 Dec 21, 2022
🔎 Hunt down social media accounts by username across social networks

Hunt down social media accounts by username across social networks Installation | Usage | Docker Notes | Contributing Installation # clone the repo $

Sherlock 38.2k Jan 01, 2023
A suite of utilities for AWS Lambda Functions that makes tracing with AWS X-Ray, structured logging and creating custom metrics asynchronously easier

A suite of utilities for AWS Lambda Functions that makes tracing with AWS X-Ray, structured logging and creating custom metrics asynchronously easier

Amazon Web Services - Labs 1.9k Jan 07, 2023
Repositorio dedicado a contener los archivos fuentes del bot de discord "Lector de Ejercicios".

Lector de Ejercicios Este bot de discord está pensado para usarse únicamente en el discord de la materia Algoritmos y Programación I, de la Facultad d

Franco Lighterman Reismann 3 Sep 17, 2022