SRJ9/django-driver27

View on GitHub
driver27/management/commands/update_results.py

Summary

Maintainability
A
1 hr
Test Coverage
from django.core.management.base import BaseCommand, CommandError
from driver27.models import Result
import csv


class Command(BaseCommand):
    help = 'Update results via csv'

    @staticmethod
    def _create_result(row):
        invalid_keywords = []
        result_fields = [f.column for f in Result._meta.get_fields() if hasattr(f, 'column')]
        for x in row:
            if x in ['qualifying', 'finish', 'points', 'race_id', 'seat_id']:
                if row[x] == '':
                    row[x] = None
                else:
                    row[x] = int(row[x])
            elif x in ['wildcard', 'fastest_lap', 'retired']:
                row[x] = bool(row[x])
            elif x not in result_fields:
                invalid_keywords.append(x)

        for invalid_keyword in invalid_keywords:
            del row[invalid_keyword]
        return Result.objects.create(**row)

    def add_arguments(self, parser):
        parser.add_argument('csv',)

    def handle(self, *args, **options):
        with open(options['csv'], 'rb') as csvfile:
            reader = csv.DictReader(csvfile, delimiter=',')
            for row in reader:
                self._create_result(row)