zoukankan      html  css  js  c++  java
  • Django--CRM--modelformset的用法

    一 . modelformset用法

        其实和modelform方法差不多,只不过是显示的时候可以直接修改,显示的select的那种模式

    复制代码
    from django.forms import modelformset_factory
    
    # 展示学习记录
    def study_record_list(request, course_record_id):
        # 这是一个类  里面必填的两个参数,一个是model 一个是ModelForm
        FormSet = modelformset_factory(models.StudyRecord, StudyRecordForm, extra=0)  # extra=0 是把多的那一行去掉
        # formset 就是一组组的表单
        formset = FormSet(queryset=models.StudyRecord.objects.filter(course_record_id=course_record_id))
    
        if request.method == 'POST':
            formset = FormSet(request.POST)
            if formset.is_valid():
                formset.save()
                return redirect(reverse('study_record_list', args=(course_record_id,)))
    
        return render(request, 'study_record_list.html', {'formset': formset})
    复制代码

      要想在前端(study_record_list.html)展示效果,在前端页面中必须加上下面这些东西:

        下面的formset是后端传过来的

      

      

      

      对学习记录初始化的过程要进行批量操作, 但是有一个问题,比如我们已经初始化话过一次,但是后来了几个同学,这时候我们在进行初始化的时候就会报错,

        已经添加过的不能再添加, 这时候我们就能用到get_or_create(没有才创建)

    复制代码
        # 学习记录初始化
        def multi_init(self):
            course_record_ids = self.request.POST.getlist('ids')
            # 给一个课程记录下的所有学生添加学习记录
            for course_record_id in course_record_ids:
                # 拿到所有的学生
                course_record_obj = models.CourseRecord.objects.filter(pk=course_record_id).first()
                all_student = course_record_obj.re_class.customer_set.all().filter(status='studying')
    
                for stuedent in all_student:
                    # models.StudyRecord.objects.create(student=stuedent,course_record_id=course_record_id)
                    # get 获取,没有才创建  后来的学生也能听初始化 已经初始化过的不在创建 (用这种就行)
                    models.StudyRecord.objects.get_or_create(student=stuedent, course_record_id=course_record_id)
                    # 先更新 在创建
                    # models.StudyRecord.objects.update_or_create(student=stuedent, course_record_id=course_record_id)
    
                # # 批量插入
                # study_record_list = []
                # for student in all_student:
                #     if models.StudyRecord.objects.filter(student=student,course_record_id=course_record_id).exists():
                #         continue
                #     obj = models.StudyRecord(student=student,course_record_id=course_record_id)
                #     study_record_list.append(obj)
                #     models.StudyRecord.objects.bulk_create(study_record_list,batch_size=10)  # 一次插10个
    复制代码

      显示的结果

      

  • 相关阅读:
    4、线程--线程同部
    3、线程--线程调度
    2、线程--线程之前的状态转换
    1、线程--Thread&Runnable创建线程
    5、JUC--实现 Callable 接口
    13、JUC--ForkJoinPool 分支/合并框架 工作窃取
    linux连接iscsi存储方法
    ORA-01031: insufficient privileges 错误解决
    【opatch打补丁】oracle10.2.0.5.0升级10.2.0.5.9 for linux
    错误 ORA-01102: cannot mount database in EXCLUSIVE mode 的处理方法
  • 原文地址:https://www.cnblogs.com/uiys/p/10673481.html
Copyright © 2011-2022 走看看