2008-04-28 09:52:21 +00:00
|
|
|
# -*- Mode: Python; -*-
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
# vi:si:et:sw=2:sts=2:ts=2
|
|
|
|
|
|
|
|
from oxutils import *
|
|
|
|
import urllib2
|
2008-04-29 19:09:10 +00:00
|
|
|
from urllib import quote, unquote
|
2008-04-28 09:52:21 +00:00
|
|
|
import re, time
|
|
|
|
import os
|
|
|
|
import time
|
|
|
|
|
|
|
|
from BeautifulSoup import BeautifulSoup
|
|
|
|
import chardet
|
|
|
|
import oxutils
|
2008-05-07 09:47:53 +00:00
|
|
|
from oxutils import stripTags, decodeHtml, findRe, findString
|
2008-04-28 09:52:21 +00:00
|
|
|
from oxutils.cache import getUrl, getUrlUnicode
|
2008-04-29 16:12:27 +00:00
|
|
|
from oxutils.normalize import normalizeTitle, normalizeImdbId
|
2008-04-28 09:52:21 +00:00
|
|
|
|
|
|
|
import google
|
|
|
|
|
2008-04-29 16:12:27 +00:00
|
|
|
def getMovieId(title, director='', year=''):
|
2008-05-08 10:43:35 +00:00
|
|
|
'''
|
|
|
|
>>> getMovieId('The Matrix')
|
|
|
|
'0133093'
|
|
|
|
'''
|
2008-04-29 16:12:27 +00:00
|
|
|
if year:
|
|
|
|
title = "%s (%s)" % (title, year)
|
|
|
|
if director:
|
|
|
|
query = 'site:imdb.com %s "%s"' % (director, title)
|
|
|
|
else:
|
|
|
|
query = 'site:imdb.com "%s"' % title
|
|
|
|
for (name, url, desc) in google.find(query, 3):
|
|
|
|
if url.startswith('http://www.imdb.com/title/tt'):
|
|
|
|
return url[28:35]
|
2008-05-10 08:07:47 +00:00
|
|
|
return ''
|
2008-04-29 16:12:27 +00:00
|
|
|
|
|
|
|
def getMovieData(imdbId):
|
|
|
|
return IMDb(imdbId).parse()
|
|
|
|
|
|
|
|
# internal functions below
|
|
|
|
def getUrlBase(imdbId):
|
|
|
|
return "http://www.imdb.com/title/tt%s" % imdbId
|
|
|
|
|
|
|
|
def getRawMovieData(imdbId):
|
|
|
|
imdbId = normalizeImdbId(imdbId)
|
2008-04-30 13:31:50 +00:00
|
|
|
data = getMovieInfo(imdbId)
|
|
|
|
data['credits'] = getMovieCredits(imdbId)
|
|
|
|
data['poster'] = getMoviePoster(imdbId)
|
|
|
|
data['connections'] = getMovieConnections(imdbId)
|
|
|
|
data['company credits'] = getMovieCompanyCredits(imdbId)
|
|
|
|
data['filming locations'] = getMovieLocations(imdbId)
|
|
|
|
data['movie connections'] = getMovieConnections(imdbId)
|
|
|
|
data['external reviews'] = getMovieExternalReviews(imdbId)
|
|
|
|
data['trivia'] = getMovieTrivia(imdbId)
|
|
|
|
data['keywords'] = getMovieKeywords(imdbId)
|
|
|
|
data['media'] = {}
|
|
|
|
data['media']['images'] = getMovieImages(imdbId)
|
|
|
|
data['media']['trailers'] = getMovieTrailers(imdbId)
|
|
|
|
return data
|
|
|
|
|
|
|
|
def getMovieInfo(imdbId):
|
2008-05-08 18:04:24 +00:00
|
|
|
data = getUrlUnicode(getUrlBase(imdbId))
|
2008-04-29 16:12:27 +00:00
|
|
|
soup = BeautifulSoup(data)
|
|
|
|
info = dict()
|
2008-05-07 09:45:00 +00:00
|
|
|
info['poster'] = findRe(data, 'name="poster".*?<img .*?src="(.*?)"')
|
2008-05-10 08:29:15 +00:00
|
|
|
if info['poster'] and '_V' in info['poster']:
|
|
|
|
info['poster']= "%s.jpg" % info['poster'].split('._V')[0]
|
2008-04-29 22:15:28 +00:00
|
|
|
|
|
|
|
for i in re.compile('<h5>(.*?):</h5>(.*?)<div class="info"', re.DOTALL).findall(data):
|
|
|
|
title = stripTags(i[0]).strip().lower()
|
|
|
|
txt= stripTags(i[1]).strip()
|
|
|
|
def cleanUp(k):
|
2008-05-07 09:47:53 +00:00
|
|
|
k = decodeHtml(k).replace(u'\xa0', ' ').strip()
|
2008-04-29 22:15:28 +00:00
|
|
|
if k.endswith('more'): k=k[:-len('more')].strip()
|
|
|
|
return k
|
|
|
|
txt = cleanUp(txt)
|
|
|
|
if title not in ('plot', 'trivia', 'filming locations', 'mpaa'):
|
|
|
|
if '|' in txt:
|
|
|
|
txt = [cleanUp(k) for k in txt.split('|')]
|
|
|
|
elif ', ' in txt:
|
|
|
|
txt = [cleanUp(k) for k in txt.split(', ')]
|
|
|
|
if not title.startswith('moviemeter'):
|
|
|
|
info[title] = txt
|
|
|
|
for key in ('user comments', 'writers (wga)'):
|
|
|
|
if key in info:
|
|
|
|
del info[key]
|
|
|
|
if 'release date' in info:
|
|
|
|
info['release date'] = info['release date'].split('\n')[0]
|
|
|
|
if 'plot' in info:
|
|
|
|
info['plot'] = info['plot'].split('| add synopsis')[0].strip()
|
|
|
|
|
|
|
|
#get Title
|
2008-04-29 16:12:27 +00:00
|
|
|
title = ''
|
2008-04-30 13:31:50 +00:00
|
|
|
year = ''
|
2008-04-29 16:12:27 +00:00
|
|
|
html_title = soup('div', {'id': 'tn15title'})
|
|
|
|
if not html_title:
|
|
|
|
html_title = soup('title')
|
|
|
|
if html_title:
|
2008-05-23 10:48:19 +00:00
|
|
|
html_title = unicode(html_title[0])
|
2008-04-29 16:12:27 +00:00
|
|
|
html_title = html_title.replace('<br />', ' ').replace(' ', ' ')
|
2008-05-07 09:47:53 +00:00
|
|
|
title = decodeHtml(html_title)
|
2008-04-29 16:12:27 +00:00
|
|
|
title = stripTags(title)
|
2008-05-07 09:45:00 +00:00
|
|
|
year = findRe(title, '\((\d{4})\)')
|
2008-04-30 13:31:50 +00:00
|
|
|
if not year:
|
2008-05-07 09:45:00 +00:00
|
|
|
year = findRe(title, '\((\d{4})')
|
2008-05-08 17:45:32 +00:00
|
|
|
_y = findRe(title, r'(\([0-9\?]{4}[/IVXLCDM]*?\))')
|
2008-05-07 09:45:00 +00:00
|
|
|
if _y:
|
|
|
|
title = title.replace(_y, '')
|
2008-04-29 16:12:27 +00:00
|
|
|
for t in ('TV series', 'TV-Series', 'TV mini-series', '(mini)', '(VG)', '(V)', '(TV)'):
|
|
|
|
title = title.replace(t, '')
|
|
|
|
title = title.strip()
|
|
|
|
if title.find(u'\xa0') > -1:
|
2008-04-29 22:15:28 +00:00
|
|
|
title = title[:title.find(u'\xa0')].strip()
|
2008-04-29 16:12:27 +00:00
|
|
|
if title.startswith('"') and title.endswith('"'):
|
|
|
|
title = title[1:-1]
|
2008-04-29 22:15:28 +00:00
|
|
|
info['title'] = title
|
2008-04-30 13:31:50 +00:00
|
|
|
info['year'] = year
|
2008-05-10 07:38:14 +00:00
|
|
|
|
2008-04-30 13:31:50 +00:00
|
|
|
#Rating
|
2008-05-10 07:38:14 +00:00
|
|
|
rating = findRe(data, '<b>([\d\.]*?)/10</b>')
|
2008-04-30 13:31:50 +00:00
|
|
|
if rating:
|
2008-05-10 07:38:14 +00:00
|
|
|
info['rating'] = float(rating)
|
2008-04-30 13:31:50 +00:00
|
|
|
else:
|
|
|
|
info['rating'] = -1
|
|
|
|
|
|
|
|
#Votes
|
2008-05-07 09:45:00 +00:00
|
|
|
votes = findRe(data, '<small>\(<a href="ratings">(.*?) votes</a>\)</small>')
|
2008-04-30 13:31:50 +00:00
|
|
|
if votes:
|
|
|
|
info['votes'] = int(votes.replace(',', ''))
|
|
|
|
else:
|
|
|
|
info['votes'] = -1
|
2008-04-29 22:15:28 +00:00
|
|
|
return info
|
|
|
|
|
2008-04-30 13:31:50 +00:00
|
|
|
def getMoviePoster(imdbId):
|
|
|
|
info = getMovieInfo(imdbId)
|
2008-04-29 22:15:28 +00:00
|
|
|
return info['poster']
|
|
|
|
|
2008-04-30 13:31:50 +00:00
|
|
|
def getMovieYear(imdbId):
|
|
|
|
info = getMovieInfo(imdbId)
|
|
|
|
return info['year']
|
|
|
|
|
|
|
|
def getMovieTitle(imdbId):
|
|
|
|
info = getMovieInfo(imdbId)
|
2008-04-29 22:15:28 +00:00
|
|
|
return info['title']
|
2008-04-29 16:12:27 +00:00
|
|
|
|
|
|
|
def creditList(data, section=None):
|
|
|
|
if section == 'cast':
|
|
|
|
credits_ = re.compile('''<tr .*?<td class="nm">(.*?)</td><td class="ddd">.*?</td><td class="char">(.*?)</td></tr>''').findall(data)
|
|
|
|
else:
|
|
|
|
credits_ = re.compile('''<tr>.*?<td valign="top">(.*?)</td><td.*?</td><td valign="top">(.*?)</td></tr>''').findall(data)
|
|
|
|
credits = []
|
|
|
|
for c_ in credits_:
|
2008-05-11 15:07:09 +00:00
|
|
|
c = [decodeHtml(c_[0]).strip(), decodeHtml(c_[1]).strip()]
|
2008-04-29 16:12:27 +00:00
|
|
|
if section=='writers':
|
|
|
|
c[1] = c[1].replace('<br>', '').strip().replace(')', '').replace('(','')
|
|
|
|
if c[1].endswith(' and'): c[1] = c[1][:-4]
|
|
|
|
credits.append(c)
|
|
|
|
return credits
|
|
|
|
|
2008-04-30 13:31:50 +00:00
|
|
|
def getMovieCredits(imdbId):
|
2008-04-29 16:12:27 +00:00
|
|
|
credits = dict()
|
|
|
|
url = "%s/fullcredits" % getUrlBase(imdbId)
|
|
|
|
data = getUrlUnicode(url)
|
|
|
|
groups = data.split('<h5>')
|
|
|
|
for g in groups:
|
|
|
|
section = re.compile('''name="(.*?)".*? href="/Glossary''').findall(g)
|
|
|
|
if section:
|
|
|
|
credits[section[0]] = creditList(g, section[0])
|
|
|
|
return credits
|
|
|
|
|
2008-04-29 19:09:10 +00:00
|
|
|
def getMovieTrailers(imdbId):
|
|
|
|
url = "%s/trailers" % getUrlBase(imdbId)
|
|
|
|
data = getUrlUnicode(url)
|
|
|
|
soup = BeautifulSoup(data)
|
|
|
|
videos = soup('div', {'class':"video-gallery"})
|
|
|
|
trailers = []
|
|
|
|
if videos:
|
|
|
|
for a in videos[0]('a'):
|
|
|
|
title = stripTags(unicode(a)).strip()
|
|
|
|
url = 'http://www.imdb.com' + a['href']
|
2008-05-07 09:45:00 +00:00
|
|
|
videoId = findRe(url, '/(vi\d*?)/')
|
2008-04-29 19:09:10 +00:00
|
|
|
iframeUrl = "http://www.imdb.com/video/trailer/%s/player" % videoId
|
|
|
|
iframe = getUrlUnicode(iframeUrl)
|
2008-05-07 09:45:00 +00:00
|
|
|
videoUrl = unquote(findRe(iframe, 'addVariable\("file", "(.*?)"'))
|
2008-04-29 19:09:10 +00:00
|
|
|
trailers.append({'title': title, 'url': url, 'iframe': iframeUrl, 'flv':videoUrl})
|
|
|
|
return trailers
|
2008-04-28 09:52:21 +00:00
|
|
|
|
2008-04-29 22:15:28 +00:00
|
|
|
def getMovieQuotes(imdbId):
|
|
|
|
url = "%s/quotes" % getUrlBase(imdbId)
|
|
|
|
data = getUrlUnicode(url)
|
2008-04-29 22:24:25 +00:00
|
|
|
quotes = re.compile('<b>(.*?)</b>:(.*?)<br>', re.DOTALL).findall(findString(data, '<a name="q'))
|
2008-04-29 22:15:28 +00:00
|
|
|
quotes = [(q[0].strip(),q[1].strip()) for q in quotes]
|
|
|
|
return quotes
|
|
|
|
|
|
|
|
def getMovieTechnical(imdbId):
|
|
|
|
url = "%s/technical" % getUrlBase(imdbId)
|
|
|
|
data = getUrlUnicode(url)
|
|
|
|
results = {}
|
|
|
|
for t in re.compile('<h5>(.*?)</h5>(.*?)<br/>', re.DOTALL).findall(data):
|
|
|
|
results[t[0].strip()] = t[1].strip()
|
|
|
|
return results
|
|
|
|
|
|
|
|
def getMovieCompanyCredits(imdbId):
|
|
|
|
url = "%s/companycredits" % getUrlBase(imdbId)
|
|
|
|
data = getUrlUnicode(url)
|
|
|
|
results = {}
|
|
|
|
for field, c in re.compile('<h2>(.*?)</h2><ul>(.*?)</ul>').findall(data):
|
|
|
|
results[field.strip()] = []
|
|
|
|
for company in re.compile('<li>(.*?)</li>').findall(c):
|
|
|
|
results[field.strip()].append(company)
|
|
|
|
return results
|
|
|
|
|
|
|
|
def getMovieLocations(imdbId):
|
|
|
|
url = "%s/locations" % getUrlBase(imdbId)
|
|
|
|
data = getUrlUnicode(url)
|
|
|
|
soup = BeautifulSoup(data)
|
|
|
|
locations = []
|
|
|
|
for key in soup('a', {'href': re.compile('^/List')}):
|
2008-05-07 09:47:53 +00:00
|
|
|
locations.append(decodeHtml(key.string))
|
2008-04-29 22:15:28 +00:00
|
|
|
return locations
|
|
|
|
|
|
|
|
def getMovieImages(imdbId, keys=('still_frame', 'poster', 'product')):
|
|
|
|
photos = {}
|
|
|
|
for key in keys:
|
|
|
|
url = "%s/mediaindex?refine=%s" % (getUrlBase(imdbId), key)
|
|
|
|
data = getUrlUnicode(url)
|
|
|
|
photos[key] = {}
|
|
|
|
for s in re.compile('''<img alt="(.*?)".*?src="(http://ia.media-imdb.com/.*?.jpg)''').findall(data):
|
|
|
|
img= "%s.jpg" % s[1].split('._V')[0]
|
|
|
|
title = s[0]
|
|
|
|
if key=='still_frame':
|
|
|
|
if not "_CR0" in s[1]:
|
|
|
|
photos[key][img] = title
|
|
|
|
else:
|
|
|
|
photos[key][img] = title
|
|
|
|
return photos
|
|
|
|
|
2008-04-29 19:09:10 +00:00
|
|
|
def getMovieStills(imdbId):
|
2008-04-29 22:15:28 +00:00
|
|
|
return getMovieImages(imdbId, ['still_frame'])['still_frame']
|
|
|
|
|
|
|
|
def getMoviePosters(imdbId):
|
2008-05-10 08:29:15 +00:00
|
|
|
posters = getMovieImages(imdbId, ['poster'])['poster']
|
|
|
|
poster = getMoviePoster(imdbId)
|
|
|
|
if poster:
|
|
|
|
posters[poster] = 'main poster'
|
|
|
|
return posters
|
|
|
|
|
2008-04-29 22:15:28 +00:00
|
|
|
def getMovieTrivia(imdbId):
|
|
|
|
url = "%s/trivia" % getUrlBase(imdbId)
|
2008-04-29 19:09:10 +00:00
|
|
|
data = getUrlUnicode(url)
|
2008-04-29 22:15:28 +00:00
|
|
|
soup = BeautifulSoup(data)
|
|
|
|
trivia = []
|
|
|
|
triviaList = []
|
|
|
|
for i in soup('ul', {'class': "trivia"}):
|
|
|
|
for t in i('li'):
|
2008-05-23 10:48:19 +00:00
|
|
|
t = unicode(t).replace('<br />', '').strip()
|
2008-04-29 22:15:28 +00:00
|
|
|
if t.startswith('<li>') and t.endswith('</li>'):
|
|
|
|
t = t[4:-5].strip()
|
2008-05-11 15:07:09 +00:00
|
|
|
t=decodeHtml(t)
|
2008-04-29 22:15:28 +00:00
|
|
|
trivia.append(t)
|
|
|
|
return trivia
|
2008-04-29 19:09:10 +00:00
|
|
|
|
2008-04-30 13:31:50 +00:00
|
|
|
def getMovieConnections(imdbId):
|
|
|
|
url = "%s/movieconnections" % getUrlBase(imdbId)
|
|
|
|
data = getUrlUnicode(url)
|
|
|
|
soup = BeautifulSoup(data)
|
|
|
|
connections = {}
|
|
|
|
content = soup('div', {'id': 'tn15content'})[0]
|
2008-05-23 10:48:19 +00:00
|
|
|
blocks = unicode(content).split('<h5>')[1:]
|
2008-04-30 13:31:50 +00:00
|
|
|
for c in blocks:
|
|
|
|
connection = c.split('</h5>')[0]
|
|
|
|
cs = BeautifulSoup(c)
|
|
|
|
if connection:
|
|
|
|
#relation -> list of imdb ids
|
2008-05-07 09:45:00 +00:00
|
|
|
connections[connection] = [findRe(a.get('href'), "\d{7}") for a in cs('a', {'href': re.compile('/title/tt')})]
|
2008-04-30 13:31:50 +00:00
|
|
|
return connections
|
|
|
|
|
|
|
|
def getMovieKeywords(imdbId):
|
|
|
|
url = "%s/keywords" % getUrlBase(imdbId)
|
|
|
|
data = getUrlUnicode(url)
|
|
|
|
soup = BeautifulSoup(data)
|
|
|
|
keywords = []
|
|
|
|
for key in soup('a', {'href': re.compile('^/keyword/')}):
|
2008-05-07 09:47:53 +00:00
|
|
|
k = decodeHtml(key.string)
|
2008-04-30 13:31:50 +00:00
|
|
|
k = k.replace(u'\xa0', ' ')
|
|
|
|
keywords.append(k)
|
|
|
|
return keywords
|
|
|
|
|
|
|
|
|
|
|
|
def getMovieExternalReviews(imdbId):
|
|
|
|
url = "%s/externalreviews" % getUrlBase(imdbId)
|
|
|
|
data = getUrlUnicode(url)
|
|
|
|
soup = BeautifulSoup(data)
|
|
|
|
ol = soup('ol')
|
|
|
|
if ol:
|
|
|
|
ol = ol[0]
|
|
|
|
ret = {}
|
|
|
|
for li in ol('li'):
|
|
|
|
try:
|
|
|
|
a = li('a')[0]
|
|
|
|
href = a.get('href')
|
|
|
|
txt = a.contents[0]
|
|
|
|
ret[href] = txt
|
|
|
|
except:
|
|
|
|
pass
|
|
|
|
return ret
|
|
|
|
return {}
|
|
|
|
|
2008-04-29 19:09:10 +00:00
|
|
|
'''the old code below'''
|
2008-04-28 09:52:21 +00:00
|
|
|
|
|
|
|
class IMDb:
|
2008-04-29 16:12:27 +00:00
|
|
|
def __init__(self, imdbId):
|
|
|
|
self.imdb = imdbId
|
2008-04-28 09:52:21 +00:00
|
|
|
self.pageUrl = "http://www.imdb.com/title/tt%s/" % self.imdb
|
|
|
|
|
|
|
|
self.businessUrl = "%sbusiness" % self.pageUrl
|
|
|
|
self.creditsUrl = "%sfullcredits" % self.pageUrl
|
|
|
|
self.episodesUrl = "%sepisodes" % self.pageUrl
|
|
|
|
self.plotUrl = "%splotsummary" % self.pageUrl
|
|
|
|
self.releaseinfoUrl = "%sreleaseinfo" % self.pageUrl
|
2008-04-29 16:12:27 +00:00
|
|
|
|
|
|
|
def getPage(self):
|
|
|
|
return getUrlUnicode(self.pageUrl)
|
2008-04-28 09:52:21 +00:00
|
|
|
|
|
|
|
def parse_raw_value(self, key, value):
|
|
|
|
if key in ('runtime', 'language', 'genre', 'country', 'tagline', 'plot_outline'):
|
|
|
|
value = unicode(value, 'utf-8')
|
2008-04-29 16:12:27 +00:00
|
|
|
value = stripTags(value).strip()
|
2008-04-28 09:52:21 +00:00
|
|
|
if key == 'runtime':
|
2008-05-07 09:45:00 +00:00
|
|
|
parsed_value = findRe(value, '(.*?) min')
|
|
|
|
parsed_value = findRe(parsed_value, '([0-9]+)')
|
2008-04-28 09:52:21 +00:00
|
|
|
if not parsed_value:
|
2008-05-07 09:45:00 +00:00
|
|
|
parsed_value = findRe(value, '(.*?) sec')
|
|
|
|
parsed_value = findRe(parsed_value, '([0-9]+)')
|
2008-04-28 09:52:21 +00:00
|
|
|
if not parsed_value:
|
|
|
|
parsed_value = 0
|
|
|
|
else:
|
|
|
|
parsed_value = int(parsed_value)
|
|
|
|
else:
|
|
|
|
parsed_value = int(parsed_value) * 60
|
|
|
|
elif key in ('country', 'language'):
|
|
|
|
parsed_value = value.split(' / ')
|
2008-05-11 15:07:09 +00:00
|
|
|
if len(parsed_value) == 1:
|
|
|
|
parsed_value = parsed_value[0].split(' | ')
|
2008-04-29 19:09:10 +00:00
|
|
|
parsed_value = [v.strip() for v in parsed_value]
|
2008-04-28 09:52:21 +00:00
|
|
|
elif key == 'genre':
|
|
|
|
parsed_value = value.replace('more', '').strip().split(' / ')
|
2008-05-11 15:07:09 +00:00
|
|
|
if len(parsed_value) == 1:
|
|
|
|
parsed_value = parsed_value[0].split(' | ')
|
2008-04-29 19:09:10 +00:00
|
|
|
parsed_value = [v.strip() for v in parsed_value]
|
2008-04-28 09:52:21 +00:00
|
|
|
elif key == 'tagline':
|
|
|
|
parsed_value = value.replace('more', '').strip()
|
|
|
|
elif key == 'plot_outline':
|
|
|
|
parsed_value = value.replace('(view trailer)', '').strip()
|
|
|
|
if parsed_value.endswith('more'):
|
|
|
|
parsed_value = parsed_value[:-4].strip()
|
|
|
|
elif key == 'tv_series':
|
|
|
|
m = re.compile('<a href="/title/tt(.*?)/">(.*?)</a>').findall(value)
|
|
|
|
if m:
|
|
|
|
parsed_value = m[0][0]
|
|
|
|
else:
|
|
|
|
parsed_value = ''
|
|
|
|
elif key == 'also_known_as':
|
|
|
|
parsed_value = ''
|
|
|
|
m = re.compile('(.*) \(International: English title').findall(value)
|
|
|
|
if m:
|
|
|
|
parsed_value = m[0]
|
|
|
|
else:
|
|
|
|
m = re.compile('(.*) \(USA').findall(value)
|
|
|
|
if m:
|
|
|
|
parsed_value = m[0]
|
|
|
|
parsed_value = parsed_value.split('<br />')[-1].split('(')[0]
|
2008-04-29 19:09:10 +00:00
|
|
|
director = self.getCredits().get('director', None)
|
2008-04-28 09:52:21 +00:00
|
|
|
if director:
|
|
|
|
director = director[0]
|
|
|
|
parsed_value = parsed_value.replace(director, '')
|
|
|
|
if parsed_value.startswith("'s"):
|
|
|
|
parsed_value = parsed_value[2:].strip()
|
|
|
|
parsed_value = parsed_value.strip()
|
|
|
|
else:
|
|
|
|
print value
|
|
|
|
parsed_value = value
|
|
|
|
return parsed_value
|
2008-04-29 16:12:27 +00:00
|
|
|
|
2008-04-28 09:52:21 +00:00
|
|
|
def parseTitle(self):
|
2008-04-30 13:31:50 +00:00
|
|
|
title = getMovieTitle(self.imdb)
|
2008-04-29 19:09:10 +00:00
|
|
|
title = normalizeTitle(title)
|
|
|
|
if title.startswith('"') and title.find('"',1) > 0 and \
|
|
|
|
title.find('"',1) == title.rfind('"'):
|
|
|
|
se = re.compile("Season (\d*), Episode (\d*)\)").findall(data)
|
|
|
|
if se:
|
|
|
|
se = se[0]
|
|
|
|
se = ' (S%02dE%02d)' % (int(se[0]), int(se[1]))
|
|
|
|
title = normalizeTitle(title[1:title.rfind('"')]) + se + title[title.rfind('"')+1:]
|
|
|
|
else:
|
|
|
|
title = normalizeTitle(title[1:title.rfind('"')]) + ':' + title[title.rfind('"')+1:]
|
2008-04-28 09:52:21 +00:00
|
|
|
return normalizeTitle(title)
|
2008-04-29 16:12:27 +00:00
|
|
|
|
2008-04-28 09:52:21 +00:00
|
|
|
def parseYear(self):
|
|
|
|
year = ''
|
|
|
|
data = self.getPage()
|
|
|
|
soup = BeautifulSoup(data)
|
|
|
|
html_title = soup('div', {'id': 'tn15title'})
|
|
|
|
if not html_title:
|
|
|
|
html_title = soup('title')
|
|
|
|
if html_title:
|
2008-05-23 10:48:19 +00:00
|
|
|
html_title = unicode(html_title[0])
|
2008-04-28 09:52:21 +00:00
|
|
|
html_title = stripTags(html_title)
|
2008-04-29 16:12:27 +00:00
|
|
|
year = re.compile('\((\d{4})\)').findall(html_title)
|
2008-04-28 09:52:21 +00:00
|
|
|
if not year:
|
2008-04-29 16:12:27 +00:00
|
|
|
year = re.compile('\((\d{4})/').findall(html_title)
|
|
|
|
if year:
|
2008-04-28 09:52:21 +00:00
|
|
|
year = year[0]
|
|
|
|
else: year = ''
|
|
|
|
return year
|
2008-04-29 16:12:27 +00:00
|
|
|
|
2008-04-28 09:52:21 +00:00
|
|
|
def parse(self):
|
|
|
|
data = self.getPage()
|
|
|
|
IMDbDict ={}
|
|
|
|
#Poster
|
2008-04-30 13:31:50 +00:00
|
|
|
IMDbDict['poster'] = getMoviePoster(self.imdb)
|
2008-04-28 09:52:21 +00:00
|
|
|
if not IMDbDict['poster']:
|
2008-04-29 16:12:27 +00:00
|
|
|
IMDbDict['poster'] = 'http://i.imdb.com/Heads/npa.gif'
|
2008-04-28 09:52:21 +00:00
|
|
|
#Title, Year
|
|
|
|
IMDbDict['year'] = self.parseYear()
|
|
|
|
IMDbDict['title'] = self.parseTitle()
|
2008-04-29 16:12:27 +00:00
|
|
|
|
2008-04-28 09:52:21 +00:00
|
|
|
#Rating
|
|
|
|
m = re.compile('<b>(.*?)/10</b>', re.IGNORECASE).search(data)
|
|
|
|
if m:
|
|
|
|
IMDbDict['rating'] = int(float(m.group(1)) * 1000)
|
|
|
|
else:
|
|
|
|
IMDbDict['rating'] = -1
|
|
|
|
#Votes
|
|
|
|
m = re.compile('<small>\(<a href="ratings">(.*?) votes</a>\)</small>', re.IGNORECASE).findall(data)
|
|
|
|
if m:
|
|
|
|
IMDbDict['votes'] = int(m[0].replace(',', ''))
|
|
|
|
else:
|
|
|
|
IMDbDict['votes'] = -1
|
|
|
|
|
|
|
|
data = data.replace('\n',' ')
|
|
|
|
#some values
|
|
|
|
keys = ('runtime', 'language', 'genre', 'country', 'tagline', 'plot_outline', 'tv_series', 'also_known_as')
|
|
|
|
for key in keys:
|
|
|
|
IMDbDict[key] = ''
|
|
|
|
IMDbDict['runtime'] = 0
|
|
|
|
soup = BeautifulSoup(data)
|
|
|
|
for info in soup('div', {'class': 'info'}):
|
2008-05-23 10:48:19 +00:00
|
|
|
key = unicode(info).split('</h5>')[0].split('<h5>')
|
2008-04-28 09:52:21 +00:00
|
|
|
if len(key) > 1:
|
2008-05-23 10:48:19 +00:00
|
|
|
raw_value = unicode(info).split('</h5>')[1]
|
2008-04-28 09:52:21 +00:00
|
|
|
key = key[1][:-1].lower().replace(' ', '_')
|
|
|
|
if key in keys:
|
|
|
|
IMDbDict[key] = self.parse_raw_value(key, raw_value)
|
|
|
|
IMDbDict['title_english'] = IMDbDict.pop('also_known_as', IMDbDict['title'])
|
|
|
|
#is episode
|
|
|
|
IMDbDict['episode_of'] = IMDbDict.pop('tv_series', '')
|
|
|
|
|
|
|
|
IMDbDict['episodes'] = self.parseEpisodes()
|
|
|
|
if IMDbDict['episodes']:
|
|
|
|
IMDbDict['tvshow'] = True
|
|
|
|
else:
|
|
|
|
IMDbDict['tvshow'] = False
|
2008-04-29 19:09:10 +00:00
|
|
|
IMDbDict['credits'] = self.getCredits()
|
2008-04-28 09:52:21 +00:00
|
|
|
IMDbDict['plot'] = self.parsePlot()
|
2008-04-30 13:31:50 +00:00
|
|
|
IMDbDict['keywords'] = getMovieKeywords(self.imdb)
|
2008-04-28 09:52:21 +00:00
|
|
|
|
2008-04-29 22:15:28 +00:00
|
|
|
IMDbDict['trivia'] = getMovieTrivia(self.imdb)
|
2008-04-30 13:31:50 +00:00
|
|
|
IMDbDict['connections'] = getMovieConnections(self.imdb)
|
|
|
|
IMDbDict['locations'] = getMovieLocations(self.imdb)
|
2008-04-28 09:52:21 +00:00
|
|
|
IMDbDict['release_date'] = self.parseReleaseinfo()
|
|
|
|
IMDbDict['business'] = self.parseBusiness()
|
2008-04-30 13:31:50 +00:00
|
|
|
IMDbDict['reviews'] = getMovieExternalReviews(self.imdb)
|
2008-04-28 09:52:21 +00:00
|
|
|
IMDbDict['stills'] = getMovieStills(self.imdb)
|
2008-04-30 13:31:50 +00:00
|
|
|
#IMDbDict['trailer'] = getMovieTrailer(self.imdb)
|
2008-04-28 09:52:21 +00:00
|
|
|
self.IMDbDict = IMDbDict
|
2008-04-29 16:12:27 +00:00
|
|
|
|
2008-04-28 09:52:21 +00:00
|
|
|
if IMDbDict['episode_of']:
|
|
|
|
episode_of =IMDb(IMDbDict['episode_of']).parse()
|
|
|
|
for key in ('country', 'language'):
|
|
|
|
if not IMDbDict[key]:
|
|
|
|
IMDbDict[key] = episode_of[key]
|
|
|
|
return self.IMDbDict
|
2008-04-29 16:12:27 +00:00
|
|
|
|
2008-04-29 19:09:10 +00:00
|
|
|
def getCredits(self):
|
2008-05-08 17:45:32 +00:00
|
|
|
raw_credits = getMovieCredits(self.imdb)
|
2008-04-28 09:52:21 +00:00
|
|
|
credits = {}
|
2008-04-29 16:12:27 +00:00
|
|
|
|
|
|
|
def getNames(creditList):
|
|
|
|
return [stripTags(c[0]) for c in creditList]
|
|
|
|
|
2008-05-11 15:07:09 +00:00
|
|
|
credits['director'] = getNames(raw_credits.get('directors', ''))
|
|
|
|
credits['writer'] = getNames(raw_credits.get('writers', ''))
|
|
|
|
credits['producer'] = getNames(raw_credits.get('producers', ''))
|
|
|
|
credits['cast'] = [(stripTags(c[0]),stripTags(c[1])) for c in raw_credits.get('cast', [])]
|
2008-04-29 16:12:27 +00:00
|
|
|
|
2008-04-28 09:52:21 +00:00
|
|
|
self.credits = credits
|
|
|
|
return self.credits
|
|
|
|
|
|
|
|
def parsePlot(self):
|
2008-04-29 16:12:27 +00:00
|
|
|
data = getUrlUnicode(self.plotUrl)
|
|
|
|
soup = BeautifulSoup(data)
|
2008-04-28 09:52:21 +00:00
|
|
|
plot = soup('p', {'class':'plotpar'})
|
|
|
|
if plot:
|
|
|
|
plot = unicode(plot[0]).split('<i>')[0]
|
|
|
|
else:
|
|
|
|
plot = u''
|
|
|
|
plot = stripTags(plot).strip()
|
|
|
|
self.plot = plot
|
|
|
|
return plot
|
2008-04-29 16:12:27 +00:00
|
|
|
|
2008-04-28 09:52:21 +00:00
|
|
|
def parseEpisodes(self):
|
|
|
|
episodes = {}
|
2008-04-29 16:12:27 +00:00
|
|
|
data = getUrlUnicode(self.episodesUrl)
|
|
|
|
cdata = data.replace('\r\n', ' ')
|
2008-04-28 09:52:21 +00:00
|
|
|
regexp = r'''<h4>Season (.*?), Episode (.*?): <a href="/title/tt(.*?)/">(.*?)</a></h4>(.*?)</b><br>(.*?)<br/>'''
|
|
|
|
reg = re.compile(regexp, re.IGNORECASE)
|
|
|
|
m = reg.findall(cdata)
|
|
|
|
for match in m:
|
|
|
|
try:
|
|
|
|
episode = "S%02dE%02d" % (int(match[0]), int(match[1]))
|
|
|
|
episodes[episode] = {}
|
|
|
|
episodes[episode]['imdb'] = match[2]
|
|
|
|
episodes[episode]['title'] = match[3].strip()
|
|
|
|
if episodes[episode]['title'].startswith('Episode #%d'%int(match[0])):
|
|
|
|
episodes[episode]['title'] = u''
|
2008-05-07 09:47:53 +00:00
|
|
|
description = decodeHtml(match[5])
|
2008-04-28 09:52:21 +00:00
|
|
|
description = stripTags(description.split('Next US airings:')[0])
|
|
|
|
episodes[episode]['description'] = description
|
|
|
|
episodes[episode]['date'] = ''
|
|
|
|
try:
|
|
|
|
d = stripTags(match[4])
|
|
|
|
d = d.replace('Original Air Date: ', '')
|
|
|
|
d = time.strftime("%Y-%m-%d", time.strptime(d, '%d %B %Y'))
|
|
|
|
episodes[episode]['date'] = d
|
|
|
|
except:
|
|
|
|
pass
|
|
|
|
except:
|
|
|
|
import traceback
|
|
|
|
print traceback.print_exc()
|
|
|
|
pass
|
|
|
|
self.episodes = episodes
|
|
|
|
return self.episodes
|
|
|
|
|
2008-04-29 16:12:27 +00:00
|
|
|
def getReleaseinfo(self):
|
|
|
|
return getUrlUnicode(self.releaseinfoUrl)
|
2008-04-28 09:52:21 +00:00
|
|
|
|
|
|
|
def parseReleaseinfo(self):
|
|
|
|
soup = BeautifulSoup(self.getReleaseinfo())
|
|
|
|
info = soup('table',{'border': '0', 'cellpadding':'2'})
|
|
|
|
if info:
|
|
|
|
for row in info[0]('tr'):
|
|
|
|
d = row('td', {'align':'right'})
|
|
|
|
if d:
|
|
|
|
try:
|
2008-05-23 10:48:19 +00:00
|
|
|
possible_date = stripTags(unicode(d[0])).strip()
|
2008-04-28 09:52:21 +00:00
|
|
|
rdate = time.strptime(possible_date, "%d %B %Y")
|
|
|
|
rdate = time.strftime('%Y-%m-%d', rdate)
|
|
|
|
return rdate
|
|
|
|
except:
|
|
|
|
pass
|
|
|
|
return None
|
2008-04-29 16:12:27 +00:00
|
|
|
|
|
|
|
def getBusiness(self):
|
|
|
|
return getUrlUnicode(self.businessUrl)
|
|
|
|
|
2008-04-28 09:52:21 +00:00
|
|
|
def parseBusiness(self):
|
|
|
|
soup = BeautifulSoup(self.getBusiness())
|
|
|
|
business = {'budget': 0, 'gross': 0, 'profit': 0}
|
|
|
|
content = soup('div', {'id': 'tn15content'})[0]
|
2008-05-23 10:48:19 +00:00
|
|
|
blocks = unicode(content).split('<h5>')[1:]
|
2008-04-28 09:52:21 +00:00
|
|
|
for c in blocks:
|
|
|
|
cs = BeautifulSoup(c)
|
|
|
|
line = c.split('</h5>')
|
|
|
|
if line:
|
|
|
|
title = line[0]
|
|
|
|
line = line[1]
|
|
|
|
if title in ['Budget', 'Gross']:
|
|
|
|
values = re.compile('\$(.*?) ').findall(line)
|
|
|
|
values = [int(value.replace(',','')) for value in values]
|
|
|
|
if values:
|
|
|
|
business[title.lower()] = max(values)
|
|
|
|
if business['budget'] and business['gross']:
|
|
|
|
business['profit'] = business['gross'] - business['budget']
|
|
|
|
return business
|
2008-04-29 16:12:27 +00:00
|
|
|
|
2008-04-28 09:52:21 +00:00
|
|
|
def guess(title, director=''):
|
|
|
|
#FIXME: proper file -> title
|
|
|
|
title = title.split('-')[0]
|
|
|
|
title = title.split('(')[0]
|
|
|
|
title = title.split('.')[0]
|
|
|
|
title = title.strip()
|
|
|
|
imdb_url = 'http://www.imdb.com/find?q=%s' % quote(title.encode('utf-8'))
|
|
|
|
return_url = ''
|
|
|
|
|
|
|
|
#lest first try google
|
|
|
|
#i.e. site:imdb.com Michael Stevens Sin
|
|
|
|
if director:
|
|
|
|
search = 'site:imdb.com %s "%s"' % (director, title)
|
|
|
|
else:
|
|
|
|
search = 'site:imdb.com "%s"' % title
|
|
|
|
for (name, url, desc) in google.find(search, 2):
|
|
|
|
if url.startswith('http://www.imdb.com/title/tt'):
|
|
|
|
return url[28:35]
|
|
|
|
|
|
|
|
try:
|
|
|
|
req = urllib2.Request(imdb_url, None, oxutils.net.DEFAULT_HEADERS)
|
|
|
|
u = urllib2.urlopen(req)
|
|
|
|
data = u.read()
|
|
|
|
return_url = u.url
|
|
|
|
u.close()
|
|
|
|
except:
|
|
|
|
return None
|
|
|
|
if return_url.startswith('http://www.imdb.com/title/tt'):
|
|
|
|
return return_url[28:35]
|
2008-04-29 16:12:27 +00:00
|
|
|
if data:
|
2008-05-07 09:45:00 +00:00
|
|
|
imdb_id = findRe(data.replace('\n', ' '), 'Popular Results.*?<ol><li>.*?<a href="/title/tt(.......)')
|
2008-04-28 09:52:21 +00:00
|
|
|
if imdb_id:
|
|
|
|
return imdb_id
|
|
|
|
|
|
|
|
imdb_url = 'http://www.imdb.com/find?q=%s;s=tt;site=aka' % quote(title.encode('utf-8'))
|
|
|
|
req = urllib2.Request(imdb_url, None, oxutils.net.DEFAULT_HEADERS)
|
|
|
|
u = urllib2.urlopen(req)
|
|
|
|
data = u.read()
|
|
|
|
return_url = u.url
|
|
|
|
u.close()
|
|
|
|
if return_url.startswith('http://www.imdb.com/title/tt'):
|
|
|
|
return return_url[28:35]
|
|
|
|
|
|
|
|
return None
|
|
|
|
|
|
|
|
def getEpisodeData(title, episode, show_url = None):
|
|
|
|
'''
|
|
|
|
Collect information about an episode.
|
2008-04-29 16:12:27 +00:00
|
|
|
|
2008-04-28 09:52:21 +00:00
|
|
|
Returns dict with title, show, description and episode
|
|
|
|
'''
|
|
|
|
episodeData = {
|
|
|
|
'title': u'',
|
|
|
|
'show': title,
|
|
|
|
'description': u'',
|
|
|
|
'episode': episode,
|
|
|
|
}
|
|
|
|
description = u''
|
|
|
|
if not show_url:
|
|
|
|
imdbid = guess(title)
|
|
|
|
else:
|
|
|
|
imdbid = "%07d" % int(re.compile('title/tt(\d*)').findall(link)[0])
|
|
|
|
if imdbid:
|
|
|
|
i = IMDb(imdbid).parse()
|
|
|
|
episodeData['title'] = i['episodes'][episode]['title']
|
|
|
|
episodeData['description'] = i['episodes'][episode]['description']
|
|
|
|
episodeData['imdb'] = i['episodes'][episode]['imdb']
|
|
|
|
return episodeData
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
import sys
|
|
|
|
#print parse(sys.argv[1])
|
|
|
|
print "imdb:", guess(sys.argv[1])
|