Проект предназначен для использования в социальной сети ВКонтакте.
Перед использованием обязательно прочтение дисклеймера (тык).
Позволяет:
- Скачивать аудиозаписи средствами браузера из списка аудиозаписей пользователя, либо из плейлиста.
- Сохранить список аудиозаписей в файл и загрузить этот файл на компьютер. В файле будет список из исполнителя и названия песни и URL, по которому находится mp3 файл песни. Песня и её URL разделены знаком табуляции –
\t
. (Однако вк динамически создаёт URL при воспроизведении аудио, поэтому найти файл по этому адресу можно будет только в течении ограниченного времени. Потом Вы получите 404). - Загрузить аудиозаписи, сохранённые в файл средствами скрипта на языке
python3
. Для этого на компьютере должен быть установлен интерпретатор python.
Если Вы хотите просто скачать аудиозаписи средствами браузера (2.1) или сохранить список аудиозаписей как текстовый файл (2.2), можете пропустить этот пункт.
-
Скачайте исходный код проекта. Это можно сделать 2 способами:
- Скачайте и разархивируйте zip-архив.
- Либо используйте git:
git clone https://github.com/artslob/VkMusicDownloader.git
-
Если Вы будете использовать питоновский скрипт:
Убедитесь, что у Вас есть интерпретатор python3 и он доступен из командной строки:
# linux which python3 # windows where python3
Затем установим виртуальное окружение:
# unix cd VkMusicDownloader python3 -m venv vk_venv source vk_venv/bin/activate python3 -m pip install -r requirements.txt # windows cd VkMusicDownloader python3 -m venv vk_venv vk_venv\Scripts\activate.bat python3 -m pip install -r requirements.txt
- Открываем содержимое файла vk-audio-downloader.js (:point_left: перейдите по этой ссылке). Выделяем весь текст (
Ctrl+A
) и копируем. - Заходим в раздел с аудиозаписями.
- Листаем в самый низ. (Чтобы прогрузились все аудиозаписи) (Можно зажать клавишу PageDown)
- Открываем консоль браузера. (
F12
-> Консоль илиCtrl+Shift+J
) - Вставляем код.
- Пролистайте в самый верх вставленного Вами кода. Найдите строку:
var VK_DOWNLOADER_HANDLER_TYPE = 'TEXT';
. ЗаменитеTEXT
наFILE
. Должно получитьсяvar VK_DOWNLOADER_HANDLER_TYPE = 'FILE';
. - Если хотите загрузить только N первых (недавно добавленных) аудиозаписей, то найдите строку
var VK_DOWNLOADER_DOWNLOAD_LATEST = 0;
. Замените0
на нужное число. Например:var VK_DOWNLOADER_DOWNLOAD_LATEST = 50;
, тогда загрузятся только 50 первых в списке аудиозаписей. - Нажмите Enter. Скачивание началось...
- Браузер может потребовать разрешение на сохранение файлов, необходимо подтвердить действие.
- Оставляем браузер на время прямо пропорциональное количеству аудиозаписей. В консоли будет отображаться прогресс скачивания.
Точно так же, как и загрузка аудиозаписей средствами браузера, только не нужно изменять TEXT
на FILE
в строке var VK_DOWNLOADER_HANDLER_TYPE = 'TEXT';
.
В конце загрузки должно появиться окно с предложением скачать текстовый файл audios.txt
. Если окно не появилось, то листните вниз страницы, там, скорее всего внизу и слева, будет ссылка с названием audios.txt
. Нажмите на неё.
После того, как Вы скачали файл со списком аудиозаписей и их URL, а также установили окружение, Вы можете использовать скрипт.
Чтобы получить помощь по параметрам скрипта, выполните команду: python3 main.py -h
.
Скрипт будет использовать параметры по умолчанию, если не указывать флаги.
Пример запуска:
python3 main.py -f /some/directory/audios.txt -d /where/to/save/audios/ -vv
-f
– путь к файлу со списком аудиозаписей. По умолчанию ищется файл с названием audios.txt
в той же директории, где лежит скрипт main.py
.
-d
– путь к директории, в которую будут загружены аудиозаписи. По умолчанию это та же директория, где лежит скрипт main.py
.
-vv
– означает высокий уровень логирования. Скрипт будет выводить полную информацию о выполнении на стандартный вывод. Можно сохранять лог в файл с помощью параметра -l
.
Текущий help скрипта (когда скрипт находится в папке /tmp
):
usage: main.py [-h] [-d DIR] [-f FILE] [-n NUMBER] [-l LOGFILE] [-v]
Download audios from text file with links.
optional arguments:
-h, --help show this help message and exit
-d DIR, --dir DIR Destination directory where audios are saved. Default:
/tmp.
-f FILE, --file FILE File that contains names of songs and their urls. Can
be set to stdin with value '-'. Default:
/tmp/audios.txt.
-n NUMBER, --number NUMBER
Number of files that downloading at the same time.
Default: 10.
-l LOGFILE, --logfile LOGFILE
Writable file for logging. By default set to stdout
with value '-'.
-v, --verbose Set level of logging. You can increase level by
repeating key. Levels by number: default: WARNING, -v:
INFO, -vv: DEBUG
- Социальная сеть ВКонтакте, о которой говорится в этом README и остальных файлах проекта, является вымышленной социальной сетью и не имеет никакого отношения к vk.com. Все действия и инструкции, представленные на этой странице, не имеют никакого отношения к реальной жизни.
- Исходный код является открытым; информация представленная в нем предназначена для ознакомления пользователей с материалами, которые могут представлять для них интерес.
- Доступ к ресурсу и исходному коду, а также использование материалов осуществляются исключительно по вашему усмотрению и без предоставления каких-либо гарантий.
- Автор(ы) кода не несут никакой ответственности за использование, распространение и прочую деятельность прочих лиц, связанную с представленными выше материалами.
- Чтение, исправление, размножение и другие действия с контентом, который размещается на ресурсе, может нарушать законодательство страны Вашего проживания, а также пользовательское соглашение, заключенное между Вами и вымешленной и, возможно, реальной социальной сетью ВКонтакте.
- Весь текст данных файлов создан с помощью случайной генерации текста.
Честно