Compare commits
2 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| ba11978e82 | |||
| 72e28e0dd7 |
@@ -3,6 +3,13 @@ from django.core.validators import MaxValueValidator, MinValueValidator
|
||||
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):
|
||||
id = models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='部门ID')
|
||||
# did = models.IntegerField("部门ID")
|
||||
@@ -44,7 +51,7 @@ class Members(models.Model):
|
||||
# 默认id作为成员id
|
||||
avatar = models.ImageField("头像", upload_to="avatar", blank=True)
|
||||
# did = models.IntegerField("所属部门ID", default=0)
|
||||
grade = models.IntegerField("年级")
|
||||
grade = models.IntegerField("年级", choices=GRADE_CHOICES)
|
||||
name = models.CharField("成员姓名", max_length=10)
|
||||
motto = models.CharField("座右铭", max_length=30)
|
||||
# department_cn = models.CharField("所属部门", max_length=10)
|
||||
|
||||
@@ -17,9 +17,9 @@ class DepartmentViewSet(APIView):
|
||||
"code": 20000,
|
||||
"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)
|
||||
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检验)
|
||||
serializer = DepartmentSerializer(data=d)
|
||||
if serializer.is_valid():
|
||||
@@ -43,7 +43,7 @@ class MemberViewSet(APIView):
|
||||
}
|
||||
grade = request.GET.get('grade')
|
||||
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
|
||||
# 对符合要求的每一个object都转为字典并通过serializer检验数据是否合法
|
||||
for x in queryset:
|
||||
@@ -77,10 +77,10 @@ class HistoryViewSet(APIView):
|
||||
"code": 20000,
|
||||
"msg": "成功",
|
||||
}
|
||||
ser = History.objects.all() # 获取全部历史列表信息
|
||||
history_list = History.objects.all() # 获取全部历史列表信息
|
||||
# 同上,对每一个object进行判断
|
||||
for x in ser:
|
||||
d = {'did': x.did, 'grade': x.grade, 'department_cn': x.department_cn}
|
||||
for x in history_list:
|
||||
d = {'did': x.department_id, 'grade': x.grade, 'department_cn': x.department_cn}
|
||||
serializer = HistorySerializer(data=d)
|
||||
if serializer.is_valid():
|
||||
continue
|
||||
@@ -97,10 +97,10 @@ class HistoryViewSet(APIView):
|
||||
y = []
|
||||
for j in range(0, 6):
|
||||
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: # 若为空,则继续判断下一个部门
|
||||
continue
|
||||
x = {'id': a.did, 'department_name': a.department_cn}
|
||||
x = {'id': a.department_id, 'department_name': a.department_cn}
|
||||
y.append(x)
|
||||
data['data'] = y
|
||||
info.append(data)
|
||||
|
||||
Reference in New Issue
Block a user