Rev 21 | Rev 29 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed
#!/p/python/pythonimport cgiimport stringimport sysimport revisionimport parseinputimport tallyfHTML = 1formaction = string.split(sys.argv[0],"/")[-1]def emitPreHTML(formaction):emitHTML("""Content-type: text/html\n<html><body><title>Hare Ballot Calculation</title><h1>Hare Ballot Calculation</h1><form enctype="multipart/form-data" method=POST action=%s><table><tr><td>CSV file of ballots:<td><input type=file size=70 name=name></table><p><input type=submit name="run1" value="Run 1 Time"><input type=submit name="run1000" value="Run 1000 Times"></form><p>Input file format is given<a href="http://www.bikmort.com/wiki/index.php?title=Hare_Voting_Procedure">here</a>.Almost no error checking is done, so be sure to review the trace output.The source code is available <a href="%s?fetch=yes">here</a>.<p><small>%s</small><hr><pre>""" % (formaction, formaction, revision.revision))returndef emitPostHTML():emitHTML("""</pre></body></html>""")returndef emitHTML(s):global fHTMLif fHTML: print sreturndef main():emitPreHTML(formaction)form = cgi.FieldStorage()if not form:emitHTML("Enter file name and press a button to see results.")elif form.has_key("fetch"):filename = string.replace(formaction, "vote.py", "tally.py")source = open(filename).read()print cgi.escape(source)elif not form.has_key("name"):emitHTML("Error: no file received")elif not form["name"].filename:emitHTML("Error: file name missing")else:name = form["name"].filenamecontents = form["name"].valuetally.trace("INPUT FILE")tally.trace(contents)nWinners, ballots = parseinput.parsestring(contents)if form.has_key("run1"):results = tally.dotally(nWinners, ballots)print "\nFINAL RESULTS"for winner in results:print "\t%s" % winnerelif form.has_key("run1000"):print "RUNNING 1000 TIMES"tally.fTrace = 0summary = {}for i in range(1000):results = str(tally.dotally(nWinners, ballots))# print "Run %2d: %s" % (i+1, results)if not summary.has_key(results):summary[results] = 0summary[results] = summary[results] + 1print "\nSUMMARY"l = summary.items()l.sort(lambda x,y: cmp(y[1], x[1]))for pair in l:print "%2d %s" % (pair[1], pair[0])else:print "UNEXPECTED SUBMIT BUTTON: %s" % formemitPostHTML()returnif __name__=='__main__':main()