Files
PyRIGS/training/management/commands/import_old_db.py

216 lines
6.1 KiB
Python

import os
import datetime
import xml.etree.ElementTree as ET
from django.core.management.base import BaseCommand
from django.conf import settings
from training import models
#from RIGS import models.Profile
class Command(BaseCommand):
epoch = datetime.date(1970, 1, 1)
def handle(self, *args, **options):
self.import_TrainingCatagory()
self.import_TrainingItem()
self.import_TrainingItemQualification()
self.import_TrainingLevel()
self.import_TrainingLevelQualification()
@staticmethod
def xml_path(file):
return os.path.join(settings.BASE_DIR, 'data/{}'.format(file))
@staticmethod
def parse_xml(file):
tree = ET.parse(file)
return tree.getroot()
def import_TrainingCatagory(self):
tally = [0, 0]
root = self.parse_xml(self.xml_path('Categories.xml'))
for child in root:
obj, created = models.TrainingCategory.objects.update_or_create(
pk=int(child.find('ID').text),
reference_number = int(child.find('Category_x0020_Number').text),
name=child.find('Category_x0020_Name').text
)
if created:
tally[1] += 1
else:
tally[0] += 1
print('Categories - Updated: {}, Created: {}'.format(tally[0], tally[1]))
def import_TrainingItem(self):
tally = [0, 0]
root = self.parse_xml(self.xml_path('Training Items.xml'))
for child in root:
if child.find('active').text == '0': active = False
else: active = True
obj, created = models.TrainingItem.objects.update_or_create(
pk = int(child.find('ID').text),
reference_number = int(child.find('Item_x0020_Number').text),
name = child.find('Item_x0020_Name').text,
category = models.TrainingCategory.objects.get(pk=int(child.find('Category_x0020_ID').text)),
active = active
)
if created:
tally[1] += 1
else:
tally[0] += 1
print('Training Items - Updated: {}, Created: {}'.format(tally[0], tally[1]))
def import_TrainingItemQualification(self):
tally = [0, 0]
root = self.parse_xml(self.xml_path('Training Records.xml'))
for child in root:
if child.find('Traning_Started_Date').text != '':
obj, created = models.TrainingItemQualification.objects.update_or_create(
pk=int(child.find('ID').text),
item = int(child.find('Training_Item_ID').text),
trainee = int(child.find('Member_ID').text),
depth = 0,
date = child.find('Traning_Started_Date').text,
supervisor = int(child.find('Training_Started_Assessor_ID').text),
notes = child.find('Training_Started_Notes').text
)
if child.find('Traning_Complete_Date').text != '':
obj, created = models.TrainingItemQualification.objects.update_or_create(
pk=int(child.find('ID').text),
item = int(child.find('Training_Item_ID').text),
trainee = int(child.find('Member_ID').text),
depth = 1,
date = child.find('Traning_Complete_Date').text,
supervisor = int(child.find('Training_Complete_Assessor_ID'),text),
notes = child.find('Training_Complete_Notes').text
)
if child.find('Competency_Assessed_Date').text != '':
obj, created = models.TrainingItemQualification.objects.update_or_create(
pk=int(child.find('ID').text),
item = int(child.find('Training_Item_ID').text),
trainee = int(child.find('Member_ID').text),
depth = 2,
date = child.find('Competency_Assessed_Date').text,
supervisor = int(child.find('Competency_Assessed_Assessor_ID'),text),
notes = child.find('Competency_Assessed_Notes').text
)
if created:
tally[1] += 1
else:
tally[0] += 1
print('Training Item Qualifications - Updated: {}, Created: {}'.format(tally[0], tally[1]))
def import_TrainingLevel(self):
tally = [0, 0]
root = self.parse_xml(self.xml_path('Training Levels'))
for child in root:
name = child.find('Level_x0020_Name').text
if name != "Technical Assistant":
depString = name.split()[-1]
levelString = name.split()[0]
else:
levelString = name
depString = None
obj, created = models.TrainingLevel.objects.update_or_create(
pk=int(child.find('ID').text),
description = name,
department = depString,
level = levelString
)
if created:
tally[1] += 1
else:
tally[0] += 1
print('Training Levels - Updated: {}, Created: {}'.format(tally[0], tally[1]))
def import_TrainingLevelQualification(self):
tally = [0, 0]
root = self.parse_xml(self.xml_path('Training Level Record'))
for child in root:
obj, created = models.TrainingLevelQualification.objects.update_or_create(
pk = int(child.find('ID').text),
trainee = int(child.find('Member_x0020_ID').text),
level = int(child.find('Training_x0020_Level_x0020_ID').text),
confirmed_on = child.find('Date_x0020_Level_x0020_Awarded').text
#confirmed by?
)
if created:
tally[1] += 1
else:
tally[0] += 1
print('TrainingLevelQualifications - Updated: {}, Created: {}'.format(tally[0], tally[1]))