summaryrefslogtreecommitdiff
path: root/choice_seeker/allotter/management
diff options
context:
space:
mode:
Diffstat (limited to 'choice_seeker/allotter/management')
-rw-r--r--choice_seeker/allotter/management/__init__.py0
-rw-r--r--choice_seeker/allotter/management/commands/__init__.py0
-rw-r--r--choice_seeker/allotter/management/commands/loadexam.py40
-rw-r--r--choice_seeker/allotter/management/commands/loadoptions.py60
-rw-r--r--choice_seeker/allotter/management/commands/loadusers.py65
5 files changed, 0 insertions, 165 deletions
diff --git a/choice_seeker/allotter/management/__init__.py b/choice_seeker/allotter/management/__init__.py
deleted file mode 100644
index e69de29..0000000
--- a/choice_seeker/allotter/management/__init__.py
+++ /dev/null
diff --git a/choice_seeker/allotter/management/commands/__init__.py b/choice_seeker/allotter/management/commands/__init__.py
deleted file mode 100644
index e69de29..0000000
--- a/choice_seeker/allotter/management/commands/__init__.py
+++ /dev/null
diff --git a/choice_seeker/allotter/management/commands/loadexam.py b/choice_seeker/allotter/management/commands/loadexam.py
deleted file mode 100644
index 2fedb66..0000000
--- a/choice_seeker/allotter/management/commands/loadexam.py
+++ /dev/null
@@ -1,40 +0,0 @@
-from csv import reader
-from django.core.management.base import BaseCommand, CommandError
-from allotter.models import Exam
-
-class Command(BaseCommand):
- args = '<file_name...>'
- help = "Give the filename of the csv file that has all the exam code and exam name relation"
-
- def handle(self, *args, **options):
-
- clean_exam()
-
- for fname in args:
- load_exam(fname)
-
- self.stdout.write('Done\n')
-
-
-def clean_exam():
- """Removes all the objects from the database, required as if not done there might be a case of multile entries"""
- data = Exam.objects.all()
- data.delete()
-
-def load_exam(filename):
- """Load exam code and exam name from the given csv file. The file should
- declare a list of "exam_code;exam_name".
- """
- try:
- csvFile = open(filename, 'rb')
- except IOError as (errno,strerror):
- print "I/O error({0}): {1}".format(errno, strerror)
-
- csvReader = reader(csvFile, delimiter=";")
-
- for data in csvReader:
- new_exam = Exam.objects.create()
- new_exam.exam_code = data[0]
- new_exam.exam_name = data[1]
- new_exam.save()
- print "Added ({0} : {1})".format(data[0], data[1]) \ No newline at end of file
diff --git a/choice_seeker/allotter/management/commands/loadoptions.py b/choice_seeker/allotter/management/commands/loadoptions.py
deleted file mode 100644
index f7c01e6..0000000
--- a/choice_seeker/allotter/management/commands/loadoptions.py
+++ /dev/null
@@ -1,60 +0,0 @@
-from optparse import make_option
-from csv import reader
-from django.core.management.base import BaseCommand
-from allotter.models import Exam, Option
-
-class Command(BaseCommand):
- option_list = BaseCommand.option_list + (
- make_option('--pcc',metavar='Paper course code file name', type=str),
- make_option('--cc',metavar='Course code file name', type=str),
- )
- help = "Give the filenames of the csv files that has all the option code, name and exam code relation"
-
- def handle(self, *args, **options):
-
- clean_option()
-
- load_option(options)
-
- self.stdout.write('Done\n')
-
-
-def clean_option():
- """Removes all the objects from the database, required as if not done there might be a case of multiple entries"""
- data = Option.objects.all()
- data.delete()
-
-def load_option(options):
- """Load option code and option name from the given csv file. The file should
- declare a list of "exam_code,option_code,option,code".
- """
- paperCourseFileName=options.get('pcc')
- courseCodeFileName=options.get('cc')
- try:
- paperCourseFile = open(paperCourseFileName, 'rb')
- except IOError as (errno,strerror):
- print "I/O error({0}): {1}".format(errno, strerror)
-
- try:
- courseCodeFile = open(courseCodeFileName, 'rb')
- except IOError as (errno,strerror):
- print "I/O error({0}): {1}".format(errno, strerror)
-
- paperReader = reader(paperCourseFile, delimiter=",")
- courseReader = reader(courseCodeFile, delimiter=",")
-
- courseDict = {}
-
- for data in courseReader:
- courseDict[int(data[0])]=data[1]
-
- for data in paperReader:
- exam = Exam.objects.get(exam_code=data[0])
- for value in data[1:len(data)]:
- try:
- new_option = Option.objects.get(opt_code=value)
- except Option.DoesNotExist:
- new_option = Option(opt_name=courseDict[int(value)],opt_code=value)
- new_option.save()
- new_option.exam.add(exam)
- print "Added (option {0} with code {1} and exam {2})".format(courseDict[int(value)],value,exam) \ No newline at end of file
diff --git a/choice_seeker/allotter/management/commands/loadusers.py b/choice_seeker/allotter/management/commands/loadusers.py
deleted file mode 100644
index 99fd075..0000000
--- a/choice_seeker/allotter/management/commands/loadusers.py
+++ /dev/null
@@ -1,65 +0,0 @@
-from optparse import make_option
-from datetime import datetime
-from csv import DictReader
-from django.core.management.base import BaseCommand
-from allotter.models import Exam, Application, User, Profile
-
-class Command(BaseCommand):
- option_list = BaseCommand.option_list + (
- make_option('--usdf',metavar='User details file name', type=str),
- )
- help = "Give the filename of the csv files that has all the details of the users"
-
- def handle(self, *args, **options):
-
- clean_users()
-
- load_users(options)
-
- self.stdout.write('Done\n')
-
-
-def clean_users():
- """Removes all the objects from the database, required as if not done there might be a case of multiple entries"""
- User.objects.filter(is_superuser=False).delete()
-
-def load_users(options):
- """Load option code and option name from the given csv file. The file should
- declare a list of "exam_code,option_code,option,code".
- """
- userDetailsFileName=options.get('usdf')
- try:
- userDetailsFile = open(userDetailsFileName, 'rb')
- except IOError as (errno,strerror):
- print "I/O error({0}): {1}".format(errno, strerror)
-
-
- userReader = DictReader(userDetailsFile, delimiter=":")
-
-
- for data in userReader:
- appno = data['AppNo.']
- regno = data['Reg.No.']
- new_user = User.objects.create_user(regno, password=appno, email="")
- application = Application(user=new_user)
- application.np = int(data['NP'])
- if data['P1'].strip():
- application.first_paper = Exam.objects.get(exam_code=data['P1'])
- try:
- application.second_paper = Exam.objects.get(exam_code=data['P2'])
- except:
- pass
- else:
- application.first_paper = Exam.objects.get(exam_code=data['P2'])
-
-
- application.nat = data['Nat']
- application.gender = data['Gdr']
- application.cent = data['Cent']
- application.cgy = data['Cgy']
- application.save()
- dob = datetime.strptime(data['DOB'], "%d/%m/%y")
- new_profile = Profile(user=new_user, application=application)
- new_profile.dob = dob
- new_profile.save()
- print "Added user with {0} and {1} with dob as {2}".format(appno,regno,dob) \ No newline at end of file