2 Commits

Author SHA1 Message Date
康家辉 ba11978e82 添加年级下拉选项 2022-05-11 21:33:19 +08:00
康家辉 72e28e0dd7 根据修改后的model修改了view 2022-05-11 21:26:01 +08:00
2 changed files with 16 additions and 9 deletions
+8 -1
View File
@@ -3,6 +3,13 @@ from django.core.validators import MaxValueValidator, MinValueValidator
from datetime import datetime from datetime import datetime
GRADE_CHOICES = (
(2003, 2003), (2004, 2004), (2005, 2005), (2006, 2006), (2007, 2007), (2008, 2008), (2009, 2009),
(2010, 2010), (2011, 2011), (2012, 2012), (2013, 2013), (2014, 2014), (2015, 2015), (2016, 2016),
(2017, 2017), (2018, 2018), (2019, 2019), (2020, 2020), (2021, 2021)
)
class Department(models.Model): class Department(models.Model):
id = models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='部门ID') id = models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='部门ID')
# did = models.IntegerField("部门ID") # did = models.IntegerField("部门ID")
@@ -44,7 +51,7 @@ class Members(models.Model):
# 默认id作为成员id # 默认id作为成员id
avatar = models.ImageField("头像", upload_to="avatar", blank=True) avatar = models.ImageField("头像", upload_to="avatar", blank=True)
# did = models.IntegerField("所属部门ID", default=0) # did = models.IntegerField("所属部门ID", default=0)
grade = models.IntegerField("年级") grade = models.IntegerField("年级", choices=GRADE_CHOICES)
name = models.CharField("成员姓名", max_length=10) name = models.CharField("成员姓名", max_length=10)
motto = models.CharField("座右铭", max_length=30) motto = models.CharField("座右铭", max_length=30)
# department_cn = models.CharField("所属部门", max_length=10) # department_cn = models.CharField("所属部门", max_length=10)
+8 -8
View File
@@ -17,9 +17,9 @@ class DepartmentViewSet(APIView):
"code": 20000, "code": 20000,
"msg": "成功", "msg": "成功",
} }
obj = Department.objects.all().filter(did=request.GET.get('did')).first() # 获取符合did的DepartmentObject obj = Department.objects.all().filter(id=request.GET.get('did')).first() # 获取符合did的DepartmentObject
# (默认每个部门只对应一个object) # (默认每个部门只对应一个object)
d = {'did': obj.did, 'department_cn': obj.department_cn, 'department_en': obj.department_en, 'content': obj.content, d = {'did': obj.id, 'department_cn': obj.department_cn, 'department_en': obj.department_en, 'content': obj.content,
'introduction': obj.introduction} # 将其转为字典类(用于放入serializer检验) 'introduction': obj.introduction} # 将其转为字典类(用于放入serializer检验)
serializer = DepartmentSerializer(data=d) serializer = DepartmentSerializer(data=d)
if serializer.is_valid(): if serializer.is_valid():
@@ -43,7 +43,7 @@ class MemberViewSet(APIView):
} }
grade = request.GET.get('grade') grade = request.GET.get('grade')
did = request.GET.get('did') did = request.GET.get('did')
queryset = Members.objects.all().filter(Q(did=did) & Q(grade=grade)) # 获得所有符合要求的object queryset = Members.objects.all().filter(Q(department_id=did) & Q(grade=grade)) # 获得所有符合要求的object
l = [] # 建一个列表用于存储最终输出的data l = [] # 建一个列表用于存储最终输出的data
# 对符合要求的每一个object都转为字典并通过serializer检验数据是否合法 # 对符合要求的每一个object都转为字典并通过serializer检验数据是否合法
for x in queryset: for x in queryset:
@@ -77,10 +77,10 @@ class HistoryViewSet(APIView):
"code": 20000, "code": 20000,
"msg": "成功", "msg": "成功",
} }
ser = History.objects.all() # 获取全部历史列表信息 history_list = History.objects.all() # 获取全部历史列表信息
# 同上,对每一个object进行判断 # 同上,对每一个object进行判断
for x in ser: for x in history_list:
d = {'did': x.did, 'grade': x.grade, 'department_cn': x.department_cn} d = {'did': x.department_id, 'grade': x.grade, 'department_cn': x.department_cn}
serializer = HistorySerializer(data=d) serializer = HistorySerializer(data=d)
if serializer.is_valid(): if serializer.is_valid():
continue continue
@@ -97,10 +97,10 @@ class HistoryViewSet(APIView):
y = [] y = []
for j in range(0, 6): for j in range(0, 6):
try: try:
a = History.objects.get(Q(did=j) & Q(grade=i)) a = History.objects.get(Q(department_id=j) & Q(grade=i))
except History.DoesNotExist: # 若为空,则继续判断下一个部门 except History.DoesNotExist: # 若为空,则继续判断下一个部门
continue continue
x = {'id': a.did, 'department_name': a.department_cn} x = {'id': a.department_id, 'department_name': a.department_cn}
y.append(x) y.append(x)
data['data'] = y data['data'] = y
info.append(data) info.append(data)