2009-01-18 15:59:37 +00:00
#.-*- coding: utf-8 -*-
2009-01-18 17:20:45 +00:00
import troggle . settings as settings
import troggle . expo . models as models
2009-01-18 15:59:37 +00:00
import csv
import re
import datetime
import os
2009-02-18 06:45:45 +00:00
import shutil
2009-05-03 07:18:22 +01:00
from troggle . save_carefully import save_carefully
2009-01-18 15:59:37 +00:00
# Julian: the below code was causing errors and it seems like a duplication of the above. Hope I haven't broken anything by commenting it. -Aaron
#
# if name in expoers2008:
# print "2008:", name
# expomissing.discard(name) # I got an error which I think was caused by this -- python complained that a set changed size during iteration.
# yo = models.Expedition.objects.filter(year = "2008")[0]
# pyo = models.PersonExpedition(person = pObject, expedition = yo, is_guest=is_guest)
# pyo.save()
2009-02-18 06:45:45 +00:00
def saveMugShot ( mugShotPath , mugShotFilename , person ) :
if mugShotFilename . startswith ( r ' i/ ' ) : #if filename in cell has the directory attached (I think they all do), remove it
mugShotFilename = mugShotFilename [ 2 : ]
else :
mugShotFilename = mugShotFilename # just in case one doesn't
mugShotObj = models . Photo (
caption = " Mugshot for " + person . first_name + " " + person . last_name ,
is_mugshot = True ,
file = mugShotFilename ,
)
shutil . copy ( mugShotPath , mugShotObj . file . path ) #Put a copy of the file in the right place. mugShotObj.file.path is determined by the django filesystemstorage specified in models.py
mugShotObj . save ( )
mugShotObj . contains_person . add ( person )
mugShotObj . save ( )
def parseMugShotAndBlurb ( personline , header , person ) :
2009-01-18 15:59:37 +00:00
#create mugshot Photo instance
2009-02-18 06:45:45 +00:00
mugShotFilename = personline [ header [ " Mugshot " ] ]
mugShotPath = os . path . join ( settings . EXPOWEB , " folk " , mugShotFilename )
2009-01-18 15:59:37 +00:00
if mugShotPath [ - 3 : ] == ' jpg ' : #if person just has an image, add it
2009-02-18 06:45:45 +00:00
saveMugShot ( mugShotPath = mugShotPath , mugShotFilename = mugShotFilename , person = person )
2009-01-18 15:59:37 +00:00
elif mugShotPath [ - 3 : ] == ' htm ' : #if person has an html page, find the image(s) and add it. Also, add the text from the html page to the "blurb" field in his model instance.
personPageOld = open ( mugShotPath , ' r ' ) . read ( )
2009-02-18 06:45:45 +00:00
person . blurb = re . search ( ' <body>.*<hr ' , personPageOld , re . DOTALL ) . group ( ) #this needs to be refined, take care of the HTML and make sure it doesn't match beyond the blurb
for mugShotFilename in re . findall ( ' i/.*?jpg ' , personPageOld , re . DOTALL ) :
mugShotPath = os . path . join ( settings . EXPOWEB , " folk " , mugShotFilename )
saveMugShot ( mugShotPath = mugShotPath , mugShotFilename = mugShotFilename , person = person )
person . save ( )
2009-01-18 15:59:37 +00:00
def LoadPersonsExpos ( ) :
persontab = open ( os . path . join ( settings . EXPOWEB , " noinfo " , " folk.csv " ) )
personreader = csv . reader ( persontab )
headers = personreader . next ( )
header = dict ( zip ( headers , range ( len ( headers ) ) ) )
2009-01-29 23:40:56 +00:00
# make expeditions
print " Loading expeditions "
2009-01-18 15:59:37 +00:00
models . Expedition . objects . all ( ) . delete ( )
years = headers [ 5 : ]
2009-02-18 06:45:45 +00:00
2009-01-18 15:59:37 +00:00
for year in years :
2009-02-16 08:31:26 +00:00
expedition = models . Expedition ( year = year , name = " CUCC expo %s " % year )
2009-01-29 23:40:56 +00:00
expedition . save ( )
2009-01-18 15:59:37 +00:00
2009-01-29 23:40:56 +00:00
# make persons
print " Loading personexpeditions "
2009-01-18 15:59:37 +00:00
models . Person . objects . all ( ) . delete ( )
models . PersonExpedition . objects . all ( ) . delete ( )
2009-05-03 06:56:03 +01:00
#expoers2008 = """Edvin Deadman,Kathryn Hopkins,Djuke Veldhuis,Becka Lawson,Julian Todd,Natalie Uomini,Aaron Curtis,Tony Rooke,Ollie Stevens,Frank Tully,Martin Jahnke,Mark Shinwell,Jess Stirrups,Nial Peters,Serena Povia,Olly Madge,Steve Jones,Pete Harley,Eeva Makiranta,Keith Curtis""".split(",")
#expomissing = set(expoers2008)
2009-01-18 15:59:37 +00:00
2009-01-29 23:40:56 +00:00
for personline in personreader :
name = personline [ header [ " Name " ] ]
2009-01-18 15:59:37 +00:00
name = re . sub ( " <.*?> " , " " , name )
mname = re . match ( " ( \ w+)(?: \ s((?:van |ten )? \ w+))?(?: \ s \ (([^)]*) \ ))? " , name )
2009-01-29 23:40:56 +00:00
nickname = mname . group ( 3 ) or " "
2009-05-03 06:56:03 +01:00
lookupAttribs = { ' first_name ' : mname . group ( 1 ) , ' last_name ' : ( mname . group ( 2 ) or " " ) }
nonLookupAttribs = { ' is_vfho ' : personline [ header [ " VfHO member " ] ] , }
person , created = save_carefully ( models . Person , lookupAttribs = lookupAttribs , nonLookupAttribs = nonLookupAttribs )
2009-03-14 08:38:55 +00:00
parseMugShotAndBlurb ( personline = personline , header = header , person = person )
2009-01-18 15:59:37 +00:00
2009-01-29 23:40:56 +00:00
# make person expedition from table
for year , attended in zip ( headers , personline ) [ 5 : ] :
expedition = models . Expedition . objects . get ( year = year )
2009-01-18 15:59:37 +00:00
if attended == " 1 " or attended == " -1 " :
2009-05-03 06:56:03 +01:00
personexpedition = models . PersonExpedition ( person = person , expedition = expedition , nickname = nickname , is_guest = ( personline [ header [ " Guest " ] ] == " 1 " ) )
2009-01-29 23:40:56 +00:00
personexpedition . save ( )
2009-01-18 15:59:37 +00:00
2009-02-18 06:45:45 +00:00
2009-01-18 15:59:37 +00:00
# this fills in those people for whom 2008 was their first expo
2009-05-03 06:56:03 +01:00
#print "Loading personexpeditions 2008"
#for name in expomissing:
# firstname, lastname = name.split()
# is_guest = name in ["Eeva Makiranta", "Keith Curtis"]
# print "2008:", name
# persons = list(models.Person.objects.filter(first_name=firstname, last_name=lastname))
# if not persons:
# person = models.Person(first_name=firstname, last_name = lastname, is_vfho = False, mug_shot = "")
# #person.Sethref()
# person.save()
# else:
# person = persons[0]
# expedition = models.Expedition.objects.get(year="2008")
# personexpedition = models.PersonExpedition(person=person, expedition=expedition, nickname="", is_guest=is_guest)
# personexpedition.save()
2009-01-29 23:40:56 +00:00
2009-02-18 06:45:45 +00:00
#Notability is now a method of person. Makes no sense to store it in the database; it would need to be recalculated every time something changes. - AC 16 Feb 09
2009-01-29 23:40:56 +00:00
# could rank according to surveying as well
2009-02-18 06:45:45 +00:00
#print "Setting person notability"
#for person in models.Person.objects.all():
#person.notability = 0.0
#for personexpedition in person.personexpedition_set.all():
#if not personexpedition.is_guest:
#person.notability += 1.0 / (2012 - int(personexpedition.expedition.year))
#person.bisnotable = person.notability > 0.3 # I don't know how to filter by this
#person.save()
2009-01-29 23:40:56 +00:00
# used in other referencing parser functions
2009-01-19 00:22:54 +00:00
# expedition name lookup cached for speed (it's a very big list)
Gpersonexpeditionnamelookup = { }
def GetPersonExpeditionNameLookup ( expedition ) :
global Gpersonexpeditionnamelookup
res = Gpersonexpeditionnamelookup . get ( expedition . name )
if res :
return res
2009-01-29 23:40:56 +00:00
res = { }
2009-01-19 00:22:54 +00:00
duplicates = set ( )
2009-01-29 23:40:56 +00:00
print " Calculating GetPersonExpeditionNameLookup for " , expedition . year
2009-01-19 00:22:54 +00:00
personexpeditions = models . PersonExpedition . objects . filter ( expedition = expedition )
for personexpedition in personexpeditions :
possnames = [ ]
f = personexpedition . person . first_name . lower ( )
l = personexpedition . person . last_name . lower ( )
if l :
possnames . append ( f + " " + l )
possnames . append ( f + " " + l [ 0 ] )
possnames . append ( f + l [ 0 ] )
possnames . append ( f [ 0 ] + " " + l )
possnames . append ( f )
if personexpedition . nickname :
possnames . append ( personexpedition . nickname . lower ( ) )
for possname in possnames :
if possname in res :
duplicates . add ( possname )
else :
res [ possname ] = personexpedition
for possname in duplicates :
del res [ possname ]
Gpersonexpeditionnamelookup [ expedition . name ] = res
return res