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
Source code of u/pekofy_bot from reddit.

pekofy-bot Source code of u/pekofy_bot from reddit. Get more info about the bot here: https://www.reddit.com/user/pekofy_bot/comments/krxxol/pekofy_bo

32 Dec 25, 2022
Python script to replace BTC adresses in the clipboard with similar looking ones, whose private key can be retrieved by a netcat listener or similar.

BTCStealer Python script to replace BTC adresses in the clipboard with similar looking ones, whose private key can be retrieved by a netcat listener o

Some Person 6 Jun 07, 2022
Petit webhook manager by moi (wassim)

Webhook Manager By wassim oubliez pas de ⭐ le projet Installations il te faut python sinon quand tu va lancer le start.bat sa va tout installer tout s

wassim 9 Jul 08, 2021
Бот Telegram для Школы в Капотне (ЦО № 1858)

co1858 Telegram Bot Активно разрабатывался в 2015-2016 году как учебный проект, с целью научиться создавать ботов для Telegram. Бот автоматически парс

Ilya Pavlov 4 Aug 30, 2022
Github integration with Telegram

The Telegram bot myGit is your GiHub assistant. In your conversations with your team, you can simply insert the information about the projects you are working at.

Alexandru Buzescu 2 Jan 06, 2022
A cut down version of QUANT containing just the model in Python (QUANTPy)

A cut down version of QUANT containing just the model in Python (QUANTPy)

2 Apr 15, 2022
Python API Client for Twitter API v2

🐍 Python Client For Twitter API v2 🚀 Why Twitter Stream ? Twitter-Stream.py a python API client for Twitter API v2 now supports FilteredStream, Samp

Twitivity 31 Nov 19, 2022
Template to create a telegram bot in python

Template for Telegram Bot Template to create a telegram bot in python. How to Run Set your telegram bot token as environment variable TELEGRAM_BOT_TOK

Ali Hejazizo 12 Aug 14, 2022
SEMID - OSINT module with lots of discord functions

SEMID Framework About Semid is a framework with different Discord functions and

Hima 20 Sep 23, 2022
An unofficial wrapper for Engineer Man's Piston API

Pistonpy Pistonpy is an API wrapper for the Piston code execution engine by Engineer Man. Key Features Simple modern and efficient Pythonic API using

AalbatrossGuy 4 Jan 03, 2022
Python script to Funge NFTs.

Python script to Funge NFTs. It scrapes OpenSea for a given list of NFT collections and downloads a certain number of NFTs from each collection or the entire collections.

3 Apr 28, 2022
Python bindings to the Syncthing REST interface.

python-syncthing Python bindings to the Syncthing REST interface. Python API Documentation Syncthing Syncthing REST Documentation Syncthing Forums $ p

Blake VandeMerwe 64 Aug 13, 2022
Python library for the eWarehousing Solutions API.

eWarehousing Solutions Python Library This library provides convenient access to the eWarehousing Solutions API from applications written in the Pytho

eWarehousing Solutions 2 Nov 09, 2022
GG Dorking is a tool to generate GitHub and Google dorking for pentesters and bug bounty hunters.

GG-Dorking GG Dorking is a python tool to generate GitHub and Google dorking links for pentesters and bug bounty hunters. It will help you to find imp

Eslam Akl 80 Nov 24, 2022
Using GNU Radio and HackRF One to Receive, Analyze and Send ASK/OOK signals

play_with_ask NIS-8016 Lab A code: Recv.grc/py: Receive signals and match with ASK button using HackRF and GNU radio. I use AM demod block(can also in

Chen Anxue 1 Jul 04, 2022
send sms via grafana alert webhook

notifier fire alarm What does this project do: the aim of this project is to send alarm notification from grafana alert manager via kavenegar api. sta

Ali Soltani 4 Oct 20, 2021
A way to export your saved reddit posts to a Notion table.

reddit-saved-to-notion A way to export your saved reddit posts and comments to a Notion table.Uses notion-sdk-py and praw for interacting with Notion

19 Sep 12, 2022
Python Telegram bot api.

pyTelegramBotAPI A simple, but extensible Python implementation for the Telegram Bot API. Getting started. Writing your first bot Prerequisites A simp

FrankWang 6.4k Jan 09, 2023
API Wrapper in Python for WeebyAPI

API Wrapper in Python for WeebyAPI

ashish 3 Feb 28, 2022
A Discord bot to easily and quickly format your JSON data

Invite PrettyJSON to your Discord server Table of contents About the project What is JSON? What is pretty printing? How to use Input options Command I

Sem 4 Jan 24, 2022