manga-dlp/mangadlp/utils.py

110 lines
3.5 KiB
Python
Raw Permalink Normal View History

import re
from pathlib import Path
from zipfile import ZipFile
2022-05-16 16:09:17 +02:00
# create an archive of the chapter images
2022-05-13 22:34:25 +02:00
def make_archive(chapter_path, file_format):
2022-05-04 19:17:12 +02:00
zip_path = Path(f"{chapter_path}.zip")
2022-05-16 16:09:17 +02:00
try:
# create zip
with ZipFile(zip_path, "w") as zipfile:
for file in chapter_path.iterdir():
zipfile.write(file, file.name)
# rename zip to file format requested
zip_path.rename(zip_path.with_suffix(file_format))
except:
raise IOError
2022-05-16 16:09:17 +02:00
def make_pdf(chapter_path):
try:
import img2pdf
except:
print("Cant import img2pdf. Please install it first")
raise ImportError
2022-05-16 16:09:17 +02:00
pdf_path = Path(f"{chapter_path}.pdf")
images = []
for file in chapter_path.iterdir():
images.append(str(file))
try:
pdf_path.write_bytes(img2pdf.convert(images))
except:
print("ERR: Can't create '.pdf' archive")
raise IOError
# create a list of chapters
def get_chapter_list(chapters):
2022-05-04 19:17:12 +02:00
chapter_list = []
for chapter in chapters.split(","):
2022-05-13 22:34:25 +02:00
# check if chapter list is with volumes and ranges
2022-05-04 19:17:12 +02:00
if "-" in chapter and ":" in chapter:
2022-05-13 22:34:25 +02:00
# split chapters and volumes apart for list generation
2022-05-04 19:17:12 +02:00
lower = chapter.split("-")[0].split(":")
upper = chapter.split("-")[1].split(":")
2022-05-13 22:34:25 +02:00
# generate range inbetween start and end --> 1-3 == 1,2,3
2022-05-04 19:17:12 +02:00
for n in range(int(lower[1]), int(upper[1]) + 1):
chapter_list.append(str(f"{lower[0]}:{n}"))
2022-05-13 22:34:25 +02:00
# no volumes, just chapter ranges
2022-05-04 19:17:12 +02:00
elif "-" in chapter:
lower = chapter.split("-")[0]
upper = chapter.split("-")[1]
2022-05-13 22:34:25 +02:00
# generate range inbetween start and end --> 1-3 == 1,2,3
2022-05-04 19:17:12 +02:00
for n in range(int(lower), int(upper) + 1):
chapter_list.append(str(n))
2022-05-13 22:34:25 +02:00
# single chapters without a range given
2022-05-04 19:17:12 +02:00
else:
chapter_list.append(chapter)
2022-05-04 19:17:12 +02:00
return chapter_list
# remove illegal characters etc
def fix_name(filename):
2022-05-04 19:17:12 +02:00
# remove illegal characters
filename = re.sub('[\\\/\<\>\:\;\|\?\*\!\@"]', "", filename)
# remove multiple dots
filename = re.sub("([\.]{2,})", ".", filename)
# remove dot(s) at the beginning and end of the filename
filename = re.sub("(^[\.]{1,})|([\.]{1,}$)", "", filename)
# remove trailing and beginning spaces
filename = re.sub("([ \t]+$)|(^[ \t]+)", "", filename)
return filename
# create name for chapter
2022-05-13 22:34:25 +02:00
def get_filename(chapter_name, chapter_vol, chapter_num, forcevol):
# if chapter is a oneshot
2022-05-04 19:17:12 +02:00
if chapter_name == "Oneshot" or chapter_num == "Oneshot":
2022-05-13 22:34:25 +02:00
return "Oneshot"
# if the chapter has no name
if not chapter_name:
return (
f"Vol. {chapter_vol} Ch. {chapter_num}"
if forcevol
else f"Ch. {chapter_num}"
)
# if the chapter has a name
# return with volume if option is set, else just the chapter num and name
return (
f"Vol. {chapter_vol} Ch. {chapter_num} - {chapter_name}"
if forcevol
else f"Ch. {chapter_num} - {chapter_name}"
)
2022-05-16 16:09:17 +02:00
def progress_bar(progress, total, verbose):
percent = int(progress / (int(total) / 100))
bar_length = 50
bar_progress = int(progress / (int(total) / bar_length))
bar_texture = "" * bar_progress
whitespace_texture = " " * (bar_length - bar_progress)
if progress == total:
2022-05-16 16:09:17 +02:00
full_bar = "" * bar_length
print(f"\r{full_bar}❙ 100%", end="\n")
else:
print(f"\r{bar_texture}{whitespace_texture}{percent}%", end="\r")