Ivan Schaller
d116465188
All checks were successful
continuous-integration/drone/push Build is passing
|
||
---|---|---|
.github/ISSUE_TEMPLATE | ||
contrib | ||
docker | ||
mangadlp | ||
tests | ||
.coveragerc | ||
.drone.yml | ||
.gitignore | ||
CHANGELOG.md | ||
conftest.py | ||
LICENSE | ||
manga-dlp.py | ||
mangas.txt | ||
MANIFEST.in | ||
README.md | ||
release-files.txt | ||
renovate.json | ||
requirements.txt | ||
set_version.sh | ||
setup.py | ||
sonar-project.properties |
manga-dlp
python script to download mangas
Description
A manga download script written in python. It only supports mangadex.org for now. But support for other sites is planned.
Before downloading a new chapter, the script always checks if there is already a chapter with the same name in the download directory. If found the chapter is skipped. So you can run the script on a schedule to only download new chapters without any additional setup.
The default behaiviour is to pack the images to a cbz archive. If
you just want the folder with all the pictures use the flag --nocbz
.
Currently Supported sites
Usage
Quick start
python3 manga-dlp.py \
--url https://mangadex.org/title/a96676e5-8ae2-425e-b549-7f15dd34a6d8/komi-san-wa-komyushou-desu \
--language "en" \
--chapters "all"
With GitHub
git clone https://github.com/olofvndrhr/manga-dlp.git # clone the repository
cd manga-dlp # go in the directory
pip install -r requirements.txt # install required packages
# on windows
python manga-dlp.py <options>
# on unix
python3 manga-dlp.py <options>
With pip (pypi)
(not yet done)
With docker
See the docker README
Options
usage: manga-dlp.py [-h] [-u URL] [-c CHAPTERS] [-p PATH] [-l LANG] [--read READ] [--list] [--nocbz] [--forcevol] [--wait WAIT]
[--verbose]
optional arguments:
-h, --help Show this help message and exit
-u URL/UUID, --url URL/UUID URL or UUID of the manga
-c CHAPTERS, --chapters CHAPTERS Chapters to download
-p PATH, --path PATH Download path. Defaults to "<script_dir>/downloads"
-l LANG, --language LANG Manga language. Defaults to "en" --> english
--read READ Path of file with manga links to download. One per line
--list List all available chapters. Defaults to false
--nocbz Dont pack it to a cbz archive. Defaults to false
--forcevol Force naming of volumes. For mangas where chapters reset each volume
--wait WAIT Time to wait for each picture to download in seconds(float). Defaults 0.5
--verbose Verbose logging. Defaults to false
Downloads file-structure
.
└── <download path>/
└── <manga title>/
└── <chapter title>/
Example:
./downloads/mangatitle/chaptertitle(.cbz)
Read list of links from file
With the option --read
you can specify a file with links to multiple mangas. They will be parsed from top to bottom
one at a time. Every link will be matched for the right api to use. It is important that you only have one link per
line, otherwise they can't be parsed.
Example:
# mangas.txt
link1
link2
link3
python3 manga-dlp.py --read mangas.txt --list
This will list all available chapters for link1, link2 and link3.
Set download path
With the option -p/--path
you can specify a path to download the chapters to. The default path
is <script_dir>/downloads
. Absolute and relative paths are supported.
Example:
python3 manga-dlp.py <other options> --path /media/mangas
This will save all mangas/chapters in the path /media/mangas/<manga title>/<chapter name>
Contribution / Bugs
For suggestions for improvement, just open a pull request.
If you want to add support for a new site, there is an api template file which you can use.
Otherwise you can open a issue with the name of the site which you want support for. (not guaranteed to be implemented)
If you encounter any bugs, also just open a issue with a description of the problem.
TODO's
Make docker container for easy distribution--> Dockerhub- Make pypi package
- Add more supported sites