From 49f06ad51b0726e654f4868661d626e2cbb8c569 Mon Sep 17 00:00:00 2001 From: morpheus65535 <5130500+morpheus65535@users.noreply.github.com> Date: Mon, 1 Jan 2018 14:29:38 -0500 Subject: [PATCH] Better exception logging when trying to guess information from filename #34 --- get_subtitle.py | 27 ++++++++++++++++----------- 1 file changed, 16 insertions(+), 11 deletions(-) diff --git a/get_subtitle.py b/get_subtitle.py index 8bad809c1..b03f34d16 100644 --- a/get_subtitle.py +++ b/get_subtitle.py @@ -16,19 +16,24 @@ else: region.configure('dogpile.cache.dbm', arguments={'filename': os.path.join(os.path.dirname(__file__), 'data/cache/cachefile.dbm')}) def download_subtitle(path, language, hi, providers, providers_auth): - video = scan_video(path) - best_subtitles = download_best_subtitles([video], {Language(language)}, providers=providers, hearing_impaired=hi, provider_configs=providers_auth) try: - best_subtitle = best_subtitles[video][0] - - result = save_subtitles(video, [best_subtitle], encoding='utf-8') - downloaded_provider = str(result[0]).strip('<>').split(' ')[0][:-8] - downloaded_language = pycountry.languages.lookup(str(str(result[0]).strip('<>').split(' ')[2].strip('[]'))).name - message = downloaded_language + " subtitles downloaded from " + downloaded_provider + "." - - return message - except: + video = scan_video(path) + except Exception as e: + logging.exception('Error trying to extract information from this filename: ' + path) return None + else: + best_subtitles = download_best_subtitles([video], {Language(language)}, providers=providers, hearing_impaired=hi, provider_configs=providers_auth) + try: + best_subtitle = best_subtitles[video][0] + + result = save_subtitles(video, [best_subtitle], encoding='utf-8') + downloaded_provider = str(result[0]).strip('<>').split(' ')[0][:-8] + downloaded_language = pycountry.languages.lookup(str(str(result[0]).strip('<>').split(' ')[2].strip('[]'))).name + message = downloaded_language + " subtitles downloaded from " + downloaded_provider + "." + + return message + except: + return None def series_download_subtitles(no): conn_db = sqlite3.connect(os.path.join(os.path.dirname(__file__), 'data/db/bazarr.db'), timeout=30)