summaryrefslogtreecommitdiff
path: root/exam/management
diff options
context:
space:
mode:
Diffstat (limited to 'exam/management')
-rw-r--r--exam/management/commands/dump_user_data.py58
-rw-r--r--exam/management/commands/results2csv.py55
2 files changed, 113 insertions, 0 deletions
diff --git a/exam/management/commands/dump_user_data.py b/exam/management/commands/dump_user_data.py
new file mode 100644
index 0000000..3a3e816
--- /dev/null
+++ b/exam/management/commands/dump_user_data.py
@@ -0,0 +1,58 @@
+# Django imports.
+from django.core.management.base import BaseCommand
+
+# Local imports.
+from exam.views import get_user_data
+from exam.models import User
+
+
+def dump_user_data(unames, stdout):
+ '''Dump user data given usernames (a sequence) if none is given dump all
+ their data. The data is dumped to stdout.
+ '''
+ if not unames:
+ try:
+ users = User.objects.all()
+ except User.DoesNotExist:
+ pass
+ else:
+ users = []
+ for uname in unames:
+ try:
+ user = User.objects.get(username__exact = uname)
+ except User.DoesNotExist:
+ stdout.write('User %s does not exist'%uname)
+ else:
+ users.append(user)
+
+ for user in users:
+ data = get_user_data(user.username)
+ stdout.write('='*80 + '\n')
+ stdout.write('Data for %s (%s)\n'%(data['name'], data['username']))
+ stdout.write('Roll Number: %s, email: %s\n'%(data['rollno'], data['email']))
+ stdout.write('-'*40 + '\n')
+ for paper in data['papers']:
+ title = "Paper: %s\n"%paper['name']
+ stdout.write(title)
+ stdout.write('-'*len(title) + '\n')
+ stdout.write('Total marks: %d\n'%paper['total'])
+ stdout.write('Questions correctly answered: %s\n'%paper['answered'])
+ stdout.write('Attempts: %d\n'%paper['attempts'])
+ stdout.write('\nAnswers\n----------\n\n')
+ for question, answer in paper['answers'].iteritems():
+ stdout.write('Question: %s\n'%question)
+ stdout.write(answer)
+ stdout.write('\n')
+
+
+class Command(BaseCommand):
+ args = '<username1> ... <usernamen>'
+ help = '''Dumps all user data to stdout, optional usernames can be
+ specified. If none is specified all user data is dumped.
+ '''
+
+ def handle(self, *args, **options):
+ """Handle the command."""
+ # Dump data.
+ dump_user_data(args, self.stdout)
+
diff --git a/exam/management/commands/results2csv.py b/exam/management/commands/results2csv.py
new file mode 100644
index 0000000..8d154e4
--- /dev/null
+++ b/exam/management/commands/results2csv.py
@@ -0,0 +1,55 @@
+# System library imports.
+import sys
+from os.path import basename
+
+# Django imports.
+from django.core.management.base import BaseCommand
+
+# Local imports.
+from exam.views import get_quiz_data
+from exam.models import Quiz
+
+def results2csv(filename, stdout):
+ """Write exam data to a CSV file. It prompts the user to choose the
+ appropriate quiz.
+ """
+ qs = Quiz.objects.all()
+
+ if len(qs) > 1:
+ print "Select quiz to save:"
+ for q in qs:
+ stdout.write('%d. %s\n'%(q.id, q.description))
+ quiz_id = int(raw_input("Please select quiz: "))
+ try:
+ quiz = Quiz.objects.get(id=quiz_id)
+ except Quiz.DoesNotExist:
+ stdout.write("Sorry, quiz %d does not exist!\n"%quiz_id)
+ sys.exit(1)
+ else:
+ quiz = qs[0]
+
+ paper_list = get_quiz_data(quiz.id)
+ stdout.write("Saving results of %s to %s ... "%(quiz.description,
+ basename(filename)))
+ f = open(filename, 'w')
+ fields = ['name', 'username', 'rollno', 'email', 'answered', 'total',
+ 'attempts']
+ SEP = ','
+ f.write(SEP.join(['"%s"'%x for x in fields]) + '\n')
+ for paper in paper_list:
+ # name, username, rollno, email, answered
+ f.write(SEP.join(['"%s"'%(paper[x]) for x in fields[:5]]) + SEP)
+ # total, attempts
+ f.write(SEP.join(['%d'%(paper[x]) for x in fields[5:]]) + '\n')
+ stdout.write('Done\n')
+
+class Command(BaseCommand):
+ args = '<results.csv>'
+ help = '''Writes out the results of a quiz to a CSV file. Prompt user
+ to select appropriate quiz if there are multiple.
+ '''
+
+ def handle(self, *args, **options):
+ """Handle the command."""
+ # Save to file.
+ results2csv(args[0], self.stdout)