This repository has been archived by the owner on Feb 2, 2018. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathimport.py
95 lines (85 loc) · 3.02 KB
/
import.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
import csv
import os
os.environ["RAPIDSMS_INI"] = "rapidsms.ini"
os.environ["DJANGO_SETTINGS_MODULE"] = "settings"
import sys
sys.path.append("..")
from rapidsms.config import Config
from rapidsms.manager import Manager
from django.core.management import execute_manager, setup_environ
conf = Config(os.environ["RAPIDSMS_INI"])
import settings
setup_environ(settings)
from malnutrition.sms.resolve import models
from apps.sms.models.base import Case, Provider
from datetime import datetime
import time
reader = csv.reader(open('migration/data/migrate-reporter.csv', 'r'))
for row in reader:
user = models.User()
user.username = str("%s-%s" % (time.time(), row[0]))
user.save()
provider = Provider()
provider.id = row[0]
provider.mobile = row[1]
provider.user = user
provider.save()
reader = csv.reader(open('migration/data/migrate-rawmessages.csv', 'r'))
for row in reader:
mlog = models.MessageLog()
provider = Provider.objects.get(id=int(row[0]))
user = provider.user
mlog.mobile = provider.mobile
mlog.user = user
mlog.text = row[1]
mlog.save()
mlog.created_at = datetime.strptime(row[2], "%Y-%m-%d %H:%M:%S")
mlog.save()
reader = csv.reader(open('migration/data/migrate-children.csv', 'r'))
for row in reader:
provider = Provider.objects.get(id=int(row[4]))
fac = models.Facility.objects.get(id=row[-2])
existing = models.Case.objects.filter(ref_id=int(row[0]), active=True, provider=provider)
for record in existing:
record.active = False
record.save()
print "Found duplicate case, setting inactive"
if row[1]:
dob = datetime.strptime(row[1], "%Y-%m-%d %H:%M:%S").date()
case = Case()
case.id = row[-1]
case.gender = row[2].upper()
case.ref_id = int(row[0])
case.dob = dob
case.mobile = row[3]
case.active = True
case.provider = provider
provider.clinic = fac
provider.save()
#case.village = models.Facility.objects.get(id=65) # this is the only one we have
case.facility = fac
case.zone = fac.zone
case.created_at = case.updated_at = datetime.now()
case.save()
else:
print "Ignoring due to bad date", row[0]
reader = csv.reader(open('migration/data/migrate-reports.csv', 'r'))
for row in reader:
report = models.ReportMalnutrition()
report.provider = models.Provider.objects.get(id=int(row[0]))
try:
report.case = models.Case.objects.get(id=int(row[-1]))
except models.Case.DoesNotExist:
print "ignoring due to case.doesnotexist"
continue
report.weight = float(row[2])
report.height = float(row[3]) * 10
if row[4]:
report.muac = int(float(row[4]) * 10)
report.save()
report.entered_at = datetime.strptime(row[7], "%Y-%m-%d %H:%M:%S")
if str(row[5]) == "1":
report.observed.add(models.Observation.objects.get(uid="oedema"))
if str(row[6]) == "1":
report.observed.add(models.Observation.objects.get(uid="diarrhea"))
report.save()