From f24444b101d486bd2118355a564d1a5ed37c1277 Mon Sep 17 00:00:00 2001 From: JackDandy Date: Tue, 12 Jan 2016 19:42:37 +0000 Subject: [PATCH] Fix handling non-numeric IMDb popular ratings. --- CHANGES.md | 7 ++++++- sickbeard/helpers.py | 8 ++++++++ sickbeard/webserve.py | 20 +++++++++----------- 3 files changed, 23 insertions(+), 12 deletions(-) diff --git a/CHANGES.md b/CHANGES.md index d6b258e2..fa223611 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -1,4 +1,9 @@ -### 0.11.0 (2016-01-10 22:30:00 UTC) +### 0.11.1 (2016-01-12 20:00:00 UTC) + +* Fix handling non-numeric IMDb popular ratings + + +### 0.11.0 (2016-01-10 22:30:00 UTC) * Change to only refresh scene exception data for shows that need it * Change reduce aggressive use of scene numbering that was overriding user preference where not needed diff --git a/sickbeard/helpers.py b/sickbeard/helpers.py index 2f0d9814..e0cbb258 100644 --- a/sickbeard/helpers.py +++ b/sickbeard/helpers.py @@ -737,6 +737,14 @@ def tryInt(s, s_default=0): return s_default +# try to convert to float, return default on failure +def tryFloat(s, s_default=0.0): + try: + return float(s) + except: + return float(s_default) + + # generates a md5 hash of a file def md5_for_file(filename, block_size=2 ** 16): try: diff --git a/sickbeard/webserve.py b/sickbeard/webserve.py index 0b8cffac..e6e5d942 100644 --- a/sickbeard/webserve.py +++ b/sickbeard/webserve.py @@ -2464,11 +2464,11 @@ class NewHomeAddShows(Home): imdb_id = re.compile(r'(?i).*(tt\d+)$') with BS4Parser(html, features=['html5lib', 'permissive']) as soup: - torrent_table = soup.find('table', {'class': 'results'}) - torrent_rows = [] if not torrent_table else torrent_table.find_all('tr') + show_list = soup.find('table', {'class': 'results'}) + shows = [] if not show_list else show_list.find_all('tr') oldest, newest, oldest_dt, newest_dt = None, None, 9999999, 0 - for tr in torrent_rows[1:]: + for tr in shows[1:]: try: url_path = tr.select('td.title a[href*=title]')[0]['href'].strip('/') ids = dict(imdb=imdb_id.sub(r'\1', url_path)) @@ -2486,15 +2486,15 @@ class NewHomeAddShows(Home): newest = year genres = tr.select('td.title span.genre') - images = tr.select('td.image img') + images = {} + img = tr.select('td.image img') overview = tr.select('td.title span.outline') rating = tr.select('td.title span.rating-rating span.value') voting = tr.select('td.title div.rating-list') - if len(images) and 'tv_series.gif' not in images[0].get('src'): - img_uri = images[0].get('src') - images = {} + if len(img): + img_uri = img[0].get('src') match = img_size.search(img_uri) - if match: + if match and 'tv_series.gif' not in img_uri: scale = lambda low1, high1: int((float(450) / high1) * low1) high = int(max([match.group(9), match.group(11)])) scaled = [scale(x, high) for x in [(int(match.group(n)), high)[high == int(match.group(n))] for n in 3, 5, 7, 9, 11]] @@ -2507,8 +2507,6 @@ class NewHomeAddShows(Home): if not ek.ek(os.path.isfile, cached_name): helpers.download_file(img_uri, cached_name) images = dict(poster=dict(thumb='cache/images/imdb/%s' % file_name)) - else: - images = {} filtered.append(dict( premiered=dt_ordinal, @@ -2520,7 +2518,7 @@ class NewHomeAddShows(Home): images=images, overview=('No overview yet' if not len(overview) else self.encode_html(overview[0].get_text()[:250:].strip())), - rating=0 if not len(rating) else int(float(rating[0].get_text()) * 10), + rating=0 if not len(rating) else int(helpers.tryFloat(rating[0].get_text()) * 10), title=tr.select('td.title a')[0].get_text().strip(), url_src_db='http://www.imdb.com/%s/' % url_path, votes=0 if not len(voting) else vote_value.sub(r'\1\2', voting[0].get('title'))))