ytb2audio
🦜 Youtube to Audio by Andrew A Levin
Install
🐍 Python
Direct install
🐳 Docker
Docker compose file
services:
ytb2audiobot:
image: andrewlevin/ytb2audiobot
environment:
- Y2A_TG_TOKEN=YOUR_TG_TOKEN
- Y2A_HASH_SALT=YOUR_HASH_SALT
restart: on-failure:3
Environment Options
Y2A_TG_TOKEN
Y2A_HASH_SALT
Y2A_OWNER_BOT_ID_TO_SAY_HELLOW
Y2A_BUTTON_CHANNEL_WAITING_DOWNLOADING_TIMEOUT_SEC
Y2A_KILL_JOB_DOWNLOAD_TIMEOUT_SEC
- Default: 2520 (seconds or 43 minutes)
Y2A_SEGMENT_AUDIO_DURATION_SEC
- Default: 2340 (seconds or 39 minutes)
Y2A_SEGMENT_AUDIO_DURATION_SPLIT_THRESHOLD_SEC
- Default: 6060 (seconds or 101 minutes)
Y2A_SEGMENT_DURATION_PADDING_SEC
Y2A_SEGMENT_REBALANCE_TO_FIT_TIMECODES
Y2A_TRANSLATION_OVERLAY_ORIGIN_AUDIO_TRANSPARENCY
Y2A_AUDIO_QUALITY_BITRATE
-
Default: 48k
-
Available Values: 48k, 64k, 96k, 128k, 196k, 256k, 320k
Y2A_DEBUG_MODE
Y2A_KEEP_DATA_FILES
Y2A_REMOVE_AGED_DATA_FILES_SEC
Y2A_AUTO_DOWNLOAD_CHAT_IDS_STORAGE_FILENAME
- Default: autodownload-hashed-chat-ids.yaml
🚴♂️ Usage and Features
Only send me Youtube URL and I'll make all
Commands
/help
/extra
/autodownload
/autodownload - Command
By default it shows lit this
Works only in Channels.
Please add this bot to the list of admins and try again.
#todo
Let you to autodownload in your channels
🔮 Advanced Options
You can call by any command
- \advanced, \adv, \ad, \extra, \ext, \ex, \options, \opt, \op
📟 CLI options
Subtitles in CLI
youtu.be/TUJmSgViGoM subtitles
youtu.be/TUJmSgViGoM subs
youtu.be/TUJmSgViGoM sub
Search word directly
youtu.be/TUJmSgViGoM subs beatles
youtu.be/TUJmSgViGoM subs sting
Set Bitrate in CLI
youtu.be/TUJmSgViGoM bitrate
youtu.be/TUJmSgViGoM bitr
youtu.be/TUJmSgViGoM bit
Call Music in CLI
youtu.be/TUJmSgViGoM music
youtu.be/TUJmSgViGoM song
🌍 Translation
Get Translation
youtu.be/TUJmSgViGoM translation
youtu.be/TUJmSgViGoM translate
youtu.be/TUJmSgViGoM transl
youtu.be/TUJmSgViGoM trans
youtu.be/TUJmSgViGoM tran
youtu.be/TUJmSgViGoM tra
youtu.be/TUJmSgViGoM tr
Set overlay background original audio volume
Default is 0.3
youtu.be/TUJmSgViGoM trans 0.6
youtu.be/TUJmSgViGoM trans 0.4
youtu.be/TUJmSgViGoM trans 0.1
Set translation without background original audio
youtu.be/TUJmSgViGoM trans 0.0
youtu.be/TUJmSgViGoM trans 0
=====
=====
Install as service unit in OS
curl -sL https://andrewalevin.github.io/ytb2audiobot/install-manual.sh | bash
Install as Docker Compose
curl -sL https://andrewalevin.github.io/ytb2audiobot/install-docker-compose.sh | bash
ytb2audiobot-view
ytb2audiobot-view
- 🔐 Privace
- 🚴♂️ Usage and Features
- 🎏 Split
- 🎶 Bitrate
- 📝 Subtitles
- 📣 Channel
- 🚀 Install your own bot server
🔐 Защита персональных данных: Рекомендации по обеспечению конфиденциальности
Ваши персональные данные – это ценность, которая заслуживает надежной защиты. Если вы разделяете мои опасения по поводу сохранности личной информации и стремитесь обеспечить максимальную конфиденциальность, следуйте этим рекомендациям:
- Оцените свои риски: Если у вас есть сомнения в безопасности ваших данных, лучше не пользоваться этим ботом.
- Установите бота на свой сервер: Чтобы контролировать все процессы и быть уверенным в безопасности, установите бота самостоятельно на свой сервер.
- Открытый код: Весь код бота публично доступен для просмотра. Можете изучить его, чтобы убедиться в отсутствии эксплойтов, скрытых сохранений данных и любых других возможных утечек ваших персональных данных.
Эти шаги помогут вам защитить свои персональные данные и обеспечить максимальную безопасность при использовании данного бота.
🚴♂️ Usage and Features
Send any youtube link to movie. Видео станет загружаться сразу автоматически.
В диалоговом окне покажется примерное время загрузки.
После успешной обрботки и загрузки в телеграм диалоговое окно будет удалено
🕰 Таймкоды для удобства прослушивания
Для вашего удобства и экономии времени к описанию ролика добавляются таймкоды, если они указаны в описании ролика на youtube.
В Телеграме при прослушивании вы можете легко перемещаться по файлу, нажимая на соответствующий таймкод. Это позволяет быстро находить нужные моменты и делать прослушивание еще более комфортным.
🎏 Split param
Вы всегда можете разделить аудиофайл для более удобного прослушивания.
Как это работает:
- По умолчанию: Все аудиофайлы, длиннее 1 часа 39 минут (как университетская лекция), автоматически разбиваются на части по 39 минут.
- Плавный переход: При разделении к предыдущей части добавляется 5 секунд из следующей, а к началу следующей части - 5 секунд из предыдущей. Это помогает понять, на каком месте вы остановились, и избежать потери информации при разделении.
- Магия золотого сечения: Если последняя часть файла меньше пропорции золотого сечения, она присоединяется к предпоследней части.
Аудиокниги: Длинная аудиокнига будет разбита на части, что облегчает загрузку файлов меньшего размера, их передачу и работу с ними.
Философские тексты: Например, "Этика" Канта. Слушать такой текст даже по 39 минут сложно, поэтому гораздо удобнее разбивать его на небольшие фрагменты по 20 минут.
Наслаждайтесь удобным прослушиванием!
Параметр
youtu.be/TUJmSgViGoM split 25
Алиасами команды для удобства использования и вспоминания добавлены
{split,spl,sp,разделить,раздел,разд,раз}
🎶 Настройка битрейта аудиофайлов
По умолчанию, загружаемые аудиофайлы конвертируются в минимальный размер с оптимальным качеством, что обеспечивает битрейт 48k.
Музыкальные файлы могут звучать лучше с более высоким качеством звука.
Как задать битрейт:
Вы можете самостоятельно задать выходной битрейт аудиофайла в диапазоне от 48k до 320k.
Для этого добавьте к отправляемой ссылке через пробел ключевое слово {bit, bitrate} и значение битрейта в тысячных.
Пример:
youtu.be/TUJmSgViGoM bit 320
Алиасами команды для удобства использования и вспоминания добавлены
{bitrate,bitr,bit,битрейт,битр,бит}
Для файла из примера получаются следюущие примеры 4 минутный клип:
- 48k bitrate - 2.1 mb file size (по-умолчанию)
- 96k bitrate - 3.5 mb file size
- 320k bitrate - 9.6 mb file size
📝 Subtitles param
Для скачивания субтитров и поиска по ним воспользуйтесь командой или ее алиасами (для удобства незапомниания :)
{subtitles,subtitle,subt,subs,sub,su,саб,сабы,субтитры,субт,суб,сб}
Без параметров: Просто введите команду, и бот скачает субтитры для текущего видео. В субтитрах будут таймкоды и ссылки на соответствующие моменты видео на YouTube.
С параметрами: Если после команды ввести слово для поиска, бот выдаст фрагменты субтитров, в которых встречается это слово.
📣 Использование бота в канале
У меня есть несколько тематических личных каналов, куда я добавляю ролики для просмотра. Теперь бот может работать и в каналах, что делает его использование еще удобнее.
Как это работает:
-
Отправьте ссылку или текст, в котором присутсвтует YouTube ссылка на видео ролик.
-
После этого появится кнопка callback. Нажмите на неё, чтобы начать скачивание аудиофайла.
Кнопка скачивания исчезнет через 8 секунд и ничего не будет происходить.
-
Вы также можете использовать команду для скачивания аудиофайла:
{download, down, dow, d, bot, скачать, скач, ск}
Все другие команды также работают в канале, обеспечивая полный функционал бота.
🚀 Install and Launche on your server
Как установить бот у себя на сервере?
Inside running directory
mkdir ytb2audiobot
cd ytb2audiobot
python3 -m venv venv
source venv/bin/activate
Telegram token paste
nano .env
TG_TOKEN_p='*** YOUR TELEGRAM TOKEN FROM BOT FATHER ***'
Run in production mode
Redirects all outputs to void
(stderr to stdout and stdout to /dev/null)
ytb2audiobot > /dev/null 2>&1
Run with in dev mode with log
Show all std in terminal and save it to stdout.log file.
ytb2audiobot | tee -a stdout.log
🤿 Техническая информация
-
Файлы скачиваются в папку datadir. Она создается в tempdir оперционной системы, а в текущей папке создается symlink для macos.
data-ytb2audiobot -> /var/folders/vd/_ygl4klj7cq01t8crn22rw7c0000gn/T/pip-ytb2audiobot-data
🏂 Todo
- Очереди для избежания flood youtube