Skip to content
This repository has been archived by the owner on Dec 30, 2024. It is now read-only.

Commit

Permalink
increased quality and optimised ffmpeg check
Browse files Browse the repository at this point in the history
  • Loading branch information
rickyrorton committed Aug 22, 2022
1 parent cdba883 commit 9b5f98a
Show file tree
Hide file tree
Showing 2 changed files with 51 additions and 34 deletions.
77 changes: 47 additions & 30 deletions downloader.py
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
# fmt: off
from datetime import datetime
from os import environ, getcwd, listdir
from os import getcwd
from os import path as ospath
from os import pathsep, remove, rename
from os import remove, rename
from platform import system
from sys import exit
from threading import Thread
Expand All @@ -24,7 +24,7 @@

# fmt: on

__version__ = "v1.68"
__version__ = "v1.69"
__supported_filetypes__ = (".m4a", ".mp3", ".wav", ".flac")


Expand Down Expand Up @@ -54,19 +54,11 @@ def checkversion():


def checkffmpeg():
ffmpeg = ["ffmpeg.exe", "ffplay.exe", "ffprobe.exe"]
dirs = environ["PATH"].split(pathsep)[0:-1]
dirs.append(getcwd())
ffmpeg_present = False
for i in dirs:
if all(j in listdir(i) for j in ffmpeg) and len(listdir(i)) != 0:
ffmpeg_present = True
break

if not ffmpeg_present:
from pydub.utils import which
if not(which("ffmpeg")):
ch = messagebox.askokcancel(
"DOWNLOAD FFMPEG",
f"Download ffmpeg to use formats like mp3,press OK to download ffmpeg",
"FFMPEG NOT FOUND",
f"Ffmpeg was not found, kindly download ffmpeg to use formats like mp3,flac and wav,press OK to download ffmpeg",
)
if ch:
if system() == "Windows":
Expand All @@ -79,14 +71,12 @@ def checkffmpeg():
"FFMPEG has been downloaded,extract the contents of the bin folder and place them in the same directory as the downloader",
)


try:
checkffmpeg()
except:
messagebox.showinfo(
"FFMPEG Check failed",
"FFMPEG executables couldnt be found to download formats other than m4a ffmpeg has to be downloaded manually",
)
print('error')
pass

ytm = YTMusic()


Expand Down Expand Up @@ -167,8 +157,13 @@ def accusearch(results, songlen):
return None


def m4atagger(mp4, m4a, song, path):
rename(mp4, m4a)
def m4atagger(input_file, m4a, song, path, bitrate, conv):
if not conv:
rename(input_file, m4a)
elif conv:
convert = AudioSegment.from_file(input_file)
convert.export(m4a, format="mp4", bitrate=bitrate)
remove(input_file)
iconname = ospath.join(
path,
remove_sus_characters(song["artists"][0]["name"] + "-" + song["name"]) + ".jpg",
Expand All @@ -189,13 +184,13 @@ def m4atagger(mp4, m4a, song, path):
remove(iconname)


def mp3convtagger(mp4, mp3, song, path, bitrate):
def mp3convtagger(webm, mp3, song, path, bitrate):
iconname = ospath.join(
path,
remove_sus_characters(song["artists"][0]["name"] + "-" + song["name"]) + ".jpg",
)
request.urlretrieve(song["album"]["images"][0]["url"], iconname)
convert = AudioSegment.from_file(mp4)
convert = AudioSegment.from_file(webm)
convert.export(mp3, format="mp3", bitrate=bitrate)
tags = ID3(mp3)
tags.add(TIT2(encoding=3, text=[song["name"]]))
Expand All @@ -209,7 +204,7 @@ def mp3convtagger(mp4, mp3, song, path, bitrate):
APIC(encoding=3, mime="image/jpeg", type=3, desc="Cover", data=f.read())
)
tags.save(v2_version=3)
remove(mp4)
remove(webm)
remove(iconname)


Expand Down Expand Up @@ -464,21 +459,43 @@ def download_song(link, scrltxt, path, filetype, button, progress, bitrate, mode
webmpath = ospath.join(path, download_name + ".webm")
try:
match filetype:
case ".m4a":
case "fast .m4a":
filetype=".m4a"
yt = vid.streams.get_audio_only()
yt.download(path, download_name + ".mp4")
m4apath = ospath.join(path, download_name + ".m4a")
m4atagger(mp4path, m4apath, song, path)
m4atagger(mp4path, m4apath, song, path, bitrate, conv=False)
add_text(
scrltxt,
f"Finished downloading and converting {song['name']}\n",
)

case "quality .m4a":
filetype=".m4a"
yt = (
vid.streams.filter(mime_type="audio/webm")
.order_by("abr")
.desc()
.first()
)
yt.download(path, download_name + ".webm")
m4apath = ospath.join(path, download_name + ".m4a")
m4atagger(webmpath, m4apath, song, path, bitrate, True)
add_text(
scrltxt,
f"Finished downloading and converting {song['name']}\n",
)

case ".mp3":
yt = vid.streams.get_audio_only()
yt.download(path, download_name + ".mp4")
yt = (
vid.streams.filter(mime_type="audio/webm")
.order_by("abr")
.desc()
.first()
)
yt.download(path, download_name + ".webm")
mp3path = ospath.join(path, download_name + ".mp3")
mp3convtagger(mp4path, mp3path, song, path, bitrate)
mp3convtagger(webmpath, mp3path, song, path, bitrate)
add_text(
scrltxt,
f"Finished downloading and converting {song['name']}\n",
Expand Down
8 changes: 4 additions & 4 deletions gui.py
Original file line number Diff line number Diff line change
Expand Up @@ -101,7 +101,7 @@ def __init__(self):
filetype = Label(
self, text="Filetype:", font=("Arial Bold", 10), bg="#333333", fg="white"
)
filetype.place(relx=0.46, rely=0.78, anchor=CENTER)
filetype.place(relx=0.45, rely=0.78, anchor=CENTER)

bitrate = Label(
self, text="Bitrate:", font=("Arial Bold", 10), bg="#333333", fg="white"
Expand Down Expand Up @@ -155,10 +155,10 @@ def __init__(self):
anchor=CENTER,
)

filetypes = [".m4a", ".mp3", ".wav", ".flac"]
self.filetype_default = StringVar(value=".m4a")
filetypes = ["fast .m4a","quality .m4a", ".mp3", ".wav", ".flac"]
self.filetype_default = StringVar(value="fast .m4a")
filetype_dropdown = OptionMenu(self, self.filetype_default, *filetypes)
filetype_dropdown.place(relx=0.52, rely=0.755)
filetype_dropdown.place(relx=0.51, rely=0.755)
# Save variable value when it is modified
self.filetype_default.trace_add("write", self.saveconf)

Expand Down

0 comments on commit 9b5f98a

Please sign in to comment.