ccdb-api/ccdb/projects/migrations/0006_project_grant_data.py
2016-01-20 12:04:07 -07:00

38 lines
1 KiB
Python

# -*- coding: utf-8 -*-
from __future__ import unicode_literals
import csv
import os
from django.db import migrations, models
def import_project_grant(apps, schema_editor):
Project = apps.get_model('projects', 'Project')
Grant = apps.get_model('projects', 'Grant')
filename = 'data/tbl_HASH_Project_Grants.csv'
if os.path.exists(filename):
with open(filename) as f:
fieldnames = ['project', 'grant']
reader = csv.DictReader(f, fieldnames=fieldnames)
for r in reader:
p = Project.objects.get(id=r['project'])
g = Grant.objects.get(id=r['grant'])
p.grants.add(g)
p.save()
def remove_project_grant(apps, schema_editor):
Grant = apps.get_model('projects', 'Grant')
Grant.projects.clear()
class Migration(migrations.Migration):
dependencies = [
('projects', '0005_grant_projects'),
]
operations = [
migrations.RunPython(import_project_grant, remove_project_grant),
]