码迷,mamicode.com
首页 > 其他好文 > 详细

CRM admin使用actions批量生成上课记录

时间:2019-09-08 09:50:21      阅读:86      评论:0      收藏:0      [点我收藏+]

标签:exce   查询   对象   res   out   djang   cep   editable   self   

使用actions字段里的函数处理选择一个班级的上课记录,然后创建这个班级学生的学习记录

 

1、在admin.py文件中加上CourseRecordAdmin,StudyRecordAdmin

actions字段里面的函数会有三个请求参数:self==CourseRecordAdmin,rquest ==request.Post,quertset==<QuerySet [<CourseRecord: 上海浦东 python全栈 4 1>

 

通过请求的queryset的值使用enrollment_set获取enrollment表中的所有数据

queryset[0].from_class.enrollment_set.all()

 

生成这个班级的学生学习记录使用bulk_creact去批量创建,先把数据都存到一个变量里面

models.StudyRecord.objects.bulk_create(study_obj)

 

如果个班级的学生记录创建了,再次去创建就会报如下的错,解决是用try捕捉

#(1062, "Duplicate entry ‘1-1‘ for key ‘crm_studyrecord_student_id_course_record_id_24d12464_uniq‘")

 

在创建学习记录StudyRecord的数据时候,student这个字段是一个外键Enrollment表的对象,我是弄成了获取一个对象下面的一个值

#print("enroll_obj.customer",enroll_obj.customer),就会报如下错误:
 #Cannot assign "<Customer: 190837349120>": "StudyRecord.student" must be a "Enrollment" instance.

 

django使用list_editable属性可以编辑,short_description actions函数名显示中文名

 

这个小功能的所有代码如下:

class CourseRecordAdmin(admin.ModelAdmin):
    
    list_display =["from_class","teacher","outline","day_num"]
    actions = ["initialization_course_record"]
    def initialization_course_record(self,request,queryset):
        #只能选择一条一个班级的上课记录
        print("self,request,queryset:",self,request,queryset)
        if len(queryset)>1:
            return HttpResponse("只能选择一条记录")
        #找出这个班报名的学生数
        #print("queryset[0]:",queryset[0].from_class.enrollment_set.all())
        #(1062, "Duplicate entry ‘1-1‘ for key ‘crm_studyrecord_student_id_course_record_id_24d12464_uniq‘")
        #Cannot assign "<Customer: 190837349120>": "StudyRecord.student" must be a "Enrollment" instance.
        study_obj=[]
        for enroll_obj in queryset[0].from_class.enrollment_set.all():
            #print("enroll_obj.customer",enroll_obj.customer)
            #如果有了就查询没有就创建,不然会报唯一性错误
            #这个是每一条一条的提交事物,如果数据太大的话性能会比较差
            # models.StudyRecord.objects.get_or_create(student=enroll_obj,
            #                                   course_record=queryset[0],
            #                                   attendance =0,
            #                                   score=0)
            study_obj.append(models.StudyRecord(
                student=enroll_obj,
                course_record=queryset[0],
                attendance=0,
                score=0))
        try:
            #bulk_create可以创建很多个但是这个事务是提交的如50条,50条失败
            models.StudyRecord.objects.bulk_create(study_obj)
            return redirect("/admin/crm/studyrecord/")
        except Exception as e:
            return HttpResponse("有些数据已经有学习记录了")
    #actions函数名显示中文名short_description
    initialization_course_record.short_description = "初始化本节上课记录"

class StudyRecordAdmin(admin.ModelAdmin):
    list_display=["student","course_record","attendance","score"]
    list_filter = ["course_record","score","attendance"]
    #可编辑的
    list_editable = ["score","attendance"]

 

 

 

CRM admin使用actions批量生成上课记录

标签:exce   查询   对象   res   out   djang   cep   editable   self   

原文地址:https://www.cnblogs.com/venvive/p/11484068.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!