summary refs log tree commit diff
diff options
context:
space:
mode:
authorNevar Angelo <psi.neamf@gmail.com>2010-11-30 18:51:00 +0200
committerNevar Angelo <psi.neamf@gmail.com>2010-11-30 18:51:00 +0200
commita1f03c7b06d0a811d18499cb2ef09405c52a5db9 (patch)
tree6af67f5aa94332c705b124735a390890c966a211
parentf8dc4414305f111a17d31f53d4a04650d80d34f5 (diff)
downloadyoutube-dl-a1f03c7b06d0a811d18499cb2ef09405c52a5db9.tar.gz
youtube-dl-a1f03c7b06d0a811d18499cb2ef09405c52a5db9.tar.xz
youtube-dl-a1f03c7b06d0a811d18499cb2ef09405c52a5db9.zip
Reworked 'upload_date' code for output sequence in YoutubeIE.
Reverted to previous version of 'upload_date' and fixed
a mistake that prevented the code from working properly.
-rwxr-xr-xyoutube-dl35
1 files changed, 8 insertions, 27 deletions
diff --git a/youtube-dl b/youtube-dl
index 24722d292..4cea2e85e 100755
--- a/youtube-dl
+++ b/youtube-dl
@@ -5,6 +5,7 @@
 # Author: Benjamin Johnson
 # License: Public domain code
 import cookielib
+import datetime
 import htmlentitydefs
 import httplib
 import locale
@@ -36,21 +37,6 @@ std_headers = {
 
 simple_title_chars = string.ascii_letters.decode('ascii') + string.digits.decode('ascii')
 
-month_name_to_number = {
-	'January':	'01',
-	'February':	'02',
-	'March':	'03',
-	'April':	'04',
-	'May':		'05',
-	'June':		'06',
-	'July':		'07',
-	'August':	'08',
-	'September':	'09',
-	'October':	'10',
-	'November':	'11',
-	'December':	'12',
-}
-
 def preferredencoding():
 	"""Get preferred encoding.
 
@@ -913,18 +899,13 @@ class YoutubeIE(InfoExtractor):
 		upload_date = u'NA'
 		mobj = re.search(r'id="eow-date".*?>(.*?)</span>', video_webpage, re.DOTALL)
 		if mobj is not None:
-			try:
-				if ',' in mobj.group(1):
-					# Month Day, Year
-					m, d, y = mobj.group(1).replace(',', '').split()
-				else:
-					# Day Month Year, we'll suppose
-					d, m, y = mobj.group(1).split()
-				m = month_name_to_number[m]
-				d = '%02d' % (long(d))
-				upload_date = '%s%s%s' % (y, m, d)
-			except:
-				upload_date = u'NA'
+			upload_date = ' '.join(re.sub(r'[/,-]', r' ', mobj.group(1)).split())
+			format_expressions = ['%d %B %Y', '%B %d %Y']
+			for expression in format_expressions:
+				try:
+					upload_date = datetime.datetime.strptime(upload_date, expression).strftime('%Y%m%d')
+				except:
+					pass
 
 		# description
 		video_description = 'No description available.'