Compare commits

..

No commits in common. "570defaea9cbd42f4e9b55704e0ed77521518740" and "06ea4e0754e11c574dd46ec6c0b79303f022609d" have entirely different histories.

5 changed files with 38 additions and 40 deletions

View File

@ -7,12 +7,3 @@ def get_movie(imdb_id):
movie = ia.get_movie(imdb_id)
return movie
def get_movie_keywords(imdb_id):
ia = IMDb()
movie = ia.get_movie(imdb_id, info="keywords")
return movie

View File

@ -14,8 +14,8 @@ def get_films_by_reference(viewings):
return viewings_filtered_by_reference_keyword
def build_page(films_by_reference_keyword):
reference_keywords_sorted = OrderedDict(sorted(films_by_reference_keyword.items(), key=lambda t: t[0]))
def build_page(reference_keywords):
reference_keywords_sorted = OrderedDict(sorted(reference_keywords.items(), key=lambda t: t[0]))
films_by_reference_table = "| Referenced | Films |\n| - | - |"

View File

@ -4,6 +4,7 @@ import base64
from collections import Counter, OrderedDict
import csv
import os
from progress.bar import IncrementalBar
from wand.image import Image
import worldmap
import warnings
@ -20,13 +21,16 @@ def get_films_by_country(viewings):
def build_page(films_by_country):
table = build_table(films_by_country)
country_count = len(films_by_country.keys())
with IncrementalBar('Generating table', max=country_count, suffix='%(percent).1f%% - %(eta)ds remaining', check_tty=False) as bar:
film_by_country_table = build_table(films_by_country, bar)
print("Drawing map")
country_counter = Counter(films_by_country)
png_data = draw_map(country_counter)
encoded = base64.b64encode(png_data).decode("utf-8")
image = "![](data:image/png;base64,{})".format(encoded)
page = image + "\n" + table
page = image + "\n" + film_by_country_table
return page
@ -34,7 +38,7 @@ def build_page(films_by_country):
def get_flags_dict():
flags = {}
with open('country-flags.csv', newline='') as f:
with open('country_flags.csv', newline='') as f:
reader = csv.reader(f, quotechar="\"")
next(reader, None) # skip the headers
@ -44,35 +48,30 @@ def get_flags_dict():
return flags
def build_table(films_by_country):
def build_table(films_by_country, bar=None):
films_by_country_sorted = OrderedDict(sorted(films_by_country.items(), key=lambda t: t[0]))
flags = get_flags_dict()
table = "| Country | Films |\n| - | - |"
for country, films in films_by_country_sorted.items():
for country in films_by_country_sorted.keys():
table += "\n"
table += country
if country in flags.keys():
table += " "
table += flags[country]
table += "{} {}".format(str(country), flags[country] if country in flags.keys() else "")
table += " | "
film_links = []
for film in films:
film_links.append("[{}](https://www.imdb.com/title/tt{}/)".format(film['title'], film['imdb_id']))
film_links = ["[{}](https://www.imdb.com/title/tt{}/)".format(film['title'], film['imdb_id']) for film in films_by_country_sorted[country]]
table += "<br>".join(film_links)
if bar is not None:
bar.next()
if bar is not None:
bar.finish()
return table
def draw_map(films_by_country, file_name="vcinema_map.svg"):
counter = Counter(films_by_country)
def draw_map(counter, file_name="vcinema_map.svg"):
countries = [k for k, v in counter.items()]
counts = [len(v) for _, v in counter.items()]

View File

@ -12,19 +12,22 @@ def get_films_by_year(viewings):
return viewings_filtered_by_year
def build_page(films_by_year):
def build_page(films_by_year, progressbar=None):
films_by_year_sorted = OrderedDict(sorted(films_by_year.items(), key=lambda t: t[0], reverse=True))
page = "| Year | Films |\n| - | - |"
page_table = "| Year | Films |\n| - | - |"
for year in films_by_year_sorted.keys():
page += "\n"
page += str(year) + " | "
page_table += "\n"
page_table += str(year) + " | "
films = []
for film in films_by_year_sorted[year]:
films.append("[{}](https://www.imdb.com/title/tt{}/)".format(film['title'], film['imdb_id']))
film_links = ["[{}](https://www.imdb.com/title/tt{}/)".format(film['title'], film['imdb_id']) for film in films_by_year_sorted[year]]
page_table += "<br>".join(film_links)
page += "<br>".join(films)
if progressbar is not None:
progressbar.next()
return page
if progressbar is not None:
progressbar.finish()
return page_table

View File

@ -96,7 +96,7 @@ def add_imdb_data_to_viewings(viewings, field_names, progress_bar=None):
progress_bar.finish()
def filter_viewings(viewings, filter_field):
def filter_viewings(viewings, filter_field, progress_bar=None):
viewings_filtered = {}
for viewing in viewings:
@ -114,4 +114,9 @@ def filter_viewings(viewings, filter_field):
else:
viewings_filtered[viewing_field] = [viewing]
if progress_bar is not None:
progress_bar.next()
progress_bar.finish()
return viewings_filtered