#! /usr/bin/env python # -*- coding: utf-8 -*- import pprint, re, subprocess, shlex, urllib import xml.etree.ElementTree as ET from mwclient import Site from datetime import datetime ###### # GLOBAL VARS ###### years = range(2015, (datetime.now()).year + 1) ######### # Site Level ######### def mwsite(host, path): #returns wiki site object site = Site(host, path) return site def mw_cats(site, args): #returns pages member of args(categories) pages = [] last_names = None # cats = site.Categories[args.category]#category, 'Graduation_work'] for category in years:#args.category: #print 'cat:', category cat = site.Categories[category]#, 'Graduation_work'] #print 'site cats:', cat, type(cat.members()) for i in list(cat.members()):# add members(objects) of cat as list, to pages list pages.append(i) #print 'pages:', pages # check whether pages are also part of Category Graduation_work for p in pages: #print 'page:', p, last_names #pages_by_name[p.name] = p if last_names == None: # what the duck am I doing here w/ last_names?? results = pages # print "\n*** p.name ***\n", [p.name for p in pages], "\n******\n" # print "\n**p.name in results****\n", [p.name for p in results], "\n******\n" return [p.name for p in results] ############################## # CATEGORIES, PAGES AND IMAGES ############################## def mw_page(site, page): page = site.Pages[page] return page def mw_page_text(site, page): text = page.text() return text def mw_page_cats(site, page): cats_list = list(page.categories()) cats = [cat.name for cat in cats_list if cat.name != u'Category:04 Publish Me'] return cats def mw_page_imgsurl(site, page, thumb): #all the imgs in a page #except thumb: if thumb: remove #returns list of tuples (img.name, img.fullurl) imgs = page.images() imgs = list(imgs) imgs_dict = { img.name:(img.imageinfo)['url'] for img in imgs if (img.imageinfo)['url'] != thumb } # exclude thumb imgs_dict = { (key.capitalize()).replace(' ','_'):value for key, value in imgs_dict.items()} # capilatize image name, so it can be called later return imgs_dict def mw_img_url(site, img): #find full of an img if 'File:' not in img: img = 'File:'+img img_page=site.Pages[img] img_url = (img_page.imageinfo)['url'] return img_url # PROCESSING MODULES def write_html_file(html_tree, filename): doctype = "" html = doctype + ET.tostring(html_tree, method='html', encoding='utf-8', ) edited = open(filename, 'w') #write edited.write(html) edited.close() def parse_work(site, title, content): workdict = {'Title':title, 'Creator':u'', 'Date':u'', 'Website':u'', 'Thumbnail':u'', 'Bio':u'', 'Description':u'', 'Extra':u''} if re.match(u'\{\{\Graduation work', content): template, extra = (re.findall(u'\{\{Graduation work\n(.*?)\}\}(.*)', content, re.DOTALL))[0] if extra: workdict['Extra'] = extra keyval = re.findall(u'\|(.*?)\=(.*?\n)', template, re.DOTALL) for pair in keyval: key = pair[0] val = (pair[1]).replace('\n', '') if 'Creator' in key: val = val.replace(u', ', u'') elif 'Thumbnail' in key: val = mw_img_url(site, val)#api_thumb_url(val) elif 'Website' in key: val = urllib.unquote( val) workdict[key]=val return workdict def pandoc2html(mw_content): '''convert individual mw sections to html''' mw_content = mw_content.encode('utf-8') tmpfile = open('./tmp_content.mw', 'w') tmpfile.write(mw_content) tmpfile.close() args_pandoc = shlex.split( 'pandoc -f mediawiki -t html5 tmp_content.mw' ) pandoc = subprocess.Popen(args_pandoc, stdout=subprocess.PIPE) html = pandoc.communicate()[0] html = html.decode("utf-8") return html author_exp = re.compile('^Authors?\: ?(.*?)\\n') cat_exp = re.compile('\[\[Category\:.*?\]\]') gallery_exp=re.compile('(.*?)', re.S) imgfile_exp=re.compile('(File:(.*?)\.(gif|jpg|jpeg|png))') def find_authors(content): authors = re.findall(author_exp, content[0:100]) #search only in 1st lines if authors: #replace authors in content content = re.sub(author_exp, '', content) authors = authors[0] else: content = content authors = None return (authors, content) def remove_cats(content): content = re.sub(cat_exp, '', content) return content print 'NO CATS', content def replace_gallery(content): content = re.sub(imgfile_exp, '[[\g<1>]]', content) #add [[ ]] to File:.*? content = re.sub(gallery_exp, '\g<1>', content) #remove gallery wrapper return content video_exp=re.compile('{\{\#widget\:Html5media.*url\=\(.*?)\<\/a\>.*?\}\}') vimeo_exp=re.compile('\{\{\#widget\:Vimeo\|id\=(.*?)\}\}') youtube_exp=re.compile('{\{\#widget\:YouTube\|id\=(.*?)\}\}') def replace_video(content): print '*** VIDEO ***' content = re.sub(vimeo_exp,"", content) content = re.sub(youtube_exp, "", content) content = re.sub(video_exp, "", content) return content img_exp=re.compile('^.*?\.(?:jpg|jpeg|JPG|JPEG|png|gif)') def replace_img_a_tag(img_anchor): # TO DO: remove - requires finding the img_anchor href = img_anchor.get('href') if re.match(img_exp, href): img_anchor.clear() figure = ET.SubElement(img_anchor, 'figure') img = ET.SubElement(figure, 'img', attrib={'src': href}) # figcaption = ET.SubElement(figure, 'figcaption') # figcaption.text = href # Index Creation def index_addwork(parent, workid, href, thumbnail, title, creator, date): child_div = ET.SubElement(parent, 'div', attrib={'class':'item', 'id':workid, 'data-title':title, 'data-creator':creator, 'data-date':date}) grandchild_a = ET.SubElement(child_div, 'a', attrib={'href':href, 'class':'work'}) if thumbnail is '': grandgrandchild_h3 = ET.SubElement(grandchild_a, 'h3', attrib={'class':'work', 'id':'thumbnail_replacement'}) grandgrandchild_h3.text=title else: grandgrandchild_img = ET.SubElement(grandchild_a, 'img', attrib={'class':'work', 'src':thumbnail}) # need to add css width to div.item