No Description

views.py 5.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. import json
  2. import sys
  3. from django.shortcuts import render
  4. from django.http.response import JsonResponse
  5. from rest_framework import status
  6. from .models import Facultad, Curso, Matricula, ProximoSemestre
  7. from rest_framework.decorators import api_view
  8. from rest_framework.parsers import JSONParser
  9. from .serializers import FacultadSerializer, CursoSerializer, MatriculaSerializer, ProximoSemestreSerializer
  10. from .organizar import files3
  11. from .matricula import files
  12. # Create your views here.
  13. @api_view(['POST', ])
  14. def insertarFacultades(request):
  15. faculties = ['Administración de Empresas', 'Administración de Empresas Graduado', 'Arquitectura', 'Arquitectura Graduado', 'Asuntos Académicos',
  16. 'Ciencias Militares', 'Ciencias Naturales', 'Ciencias Naturales Graduado', 'Ciencias Sociales', 'Ciencias Sociales Graduado',
  17. 'Escuela de Comunicación', 'Escuela de Comunicación Graduada', 'Educación', 'Educación Continua (BEOF)', 'Educación Graduado',
  18. 'Escuela de Derecho', 'Escuela Graduada de Ciencias y Tecnologías de la Información', 'Estudios Generales', 'Humanidades',
  19. 'Humanidades Graduado', 'Planificación']
  20. if request.method == 'POST':
  21. for faculty in faculties:
  22. facultad_serializer = FacultadSerializer(data={'fname': faculty})
  23. if facultad_serializer.is_valid():
  24. facultad_serializer.save()
  25. return JsonResponse({"message": 'se crearon todas las facultades'}, status=status.HTTP_201_CREATED)
  26. @api_view(['POST', ])
  27. def insertarTodosLosCursos(request):
  28. if request.method == 'POST':
  29. i = 1
  30. for file in files3:
  31. check = file['file'].split('.')
  32. path = "C:/Users/danie/Documents/Projects/Companion App/server/segundo_sem" if check[
  33. 0][-1] == '2' else "C:/Users/danie/Documents/Projects/Companion App/server/primer_sem"
  34. with open(path + '/' + file['file']) as f:
  35. data = json.load(f)
  36. fac_id = file['num']
  37. for key in data:
  38. if key != 'Horario ':
  39. code = key
  40. name = data[key][0]
  41. creds = data[key][1]
  42. try:
  43. curso = Curso.objects.get(code=code)
  44. except Curso.DoesNotExist:
  45. curso = None
  46. if curso == None:
  47. curso_serializer = CursoSerializer(
  48. data={'name': name, 'code': code, 'creditos': creds, 'fac_id': fac_id})
  49. if curso_serializer.is_valid():
  50. curso_serializer.save()
  51. else:
  52. print('ya se creo', i)
  53. i += 1
  54. return JsonResponse({'message': 'se insertaron todos los cursos'}, status=status.HTTP_201_CREATED)
  55. @api_view(['GET', 'POST'])
  56. def hello_world(request):
  57. if request.method == 'POST':
  58. return JsonResponse({"message": "Got some data!", "data": request.data})
  59. return JsonResponse({"message": "Hello, world!"})
  60. @api_view(['POST', ])
  61. def insertarProximoSemestre(request):
  62. if request.method == 'POST':
  63. for file in files:
  64. path = "C:/Users/danie/Documents/Projects/Companion App/server/Matricula Parse"
  65. with open(path + '/' + file['file']) as f:
  66. data = json.load(f)
  67. for course in data:
  68. print(course["Curso"])
  69. print(Curso.objects.filter(code=course["Curso"]))
  70. code = Curso.objects.get(code=course["Curso"])
  71. section = course["Seccion"]
  72. prof = course["Profesor"]
  73. days = ""
  74. for i in course["Dias"]:
  75. days += i
  76. days += " "
  77. hours = ""
  78. for i in course["Horario"]:
  79. hours += i
  80. hours += " "
  81. if hours == "":
  82. hours = "TBA"
  83. rooms = ""
  84. for i in course["Salones"]:
  85. rooms += i
  86. rooms += " "
  87. if rooms == "":
  88. rooms = "TBA"
  89. print(
  90. f"code {code.code}, section {section}, prof {prof}, hours {hours}, rooms {rooms}, days {days}")
  91. # extra_info = course["Info_Extra"]
  92. matricula_serializer = ProximoSemestreSerializer(
  93. data={'code': code.code, 'name': code.name, 'fac_id': code.fac_id.pk, 'course_id': code.pk, 'section': section, 'prof': prof, 'hours': hours, 'rooms': rooms, 'days': days})
  94. if matricula_serializer.is_valid(raise_exception=True):
  95. matricula_serializer.save()
  96. print("inserted some data")
  97. return JsonResponse({'message': 'se insertaron todos los cursos'}, status=status.HTTP_201_CREATED)
  98. @api_view(['POST', ])
  99. def fetchMatricula(request):
  100. json = []
  101. for i in ProximoSemestre.objects.all():
  102. json.append({"id": i.course_id.fac_id.id, "name": i.course_id.name,
  103. "code": i.course_id.code, "credits": i.course_id.creditos,
  104. "section": i.section, "prof": i.prof, "hours": i.hours,
  105. "days": i.days, "rooms": i.rooms})
  106. return JsonResponse(json, safe=False)