Compare commits
2 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| ba11978e82 | |||
| 72e28e0dd7 |
@@ -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)
|
||||||
|
|||||||
@@ -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)
|
||||||
|
|||||||
Reference in New Issue
Block a user