Python+Django实现智慧校园考试比赛系统

简介: Python+Django实现智慧校园考试比赛系统

项目编号:BS-Python-002

1.项目说明

  • 项目名称:智慧答题系统
  • 项目版本:V 1.0
  • 版本变化:无
  • 完成日期:2022年1月20日

2.  系统环境


Windows或Linux发行版(Ubuntu16.04 / CentOS等)


MySQL 5.5以上版本


Python3.5以上版本


Redis任意新版本即可


Django版本2.1


本项目基于Python+Django技术开发实现,开发工具IDEA,数据库MYSQL5.7


主要实现题库设置,比赛生成,在线答题,自动排名,自动组卷,自动改卷等相关功能。


下面展示一下系统的相关功能:

image.png

用户注册

image.png

登陆

image.png

快速出题

image.png

配置比赛

image.png

上传题库

image.png

参与比赛

image.png

开始作题

image.png

image.png

自动阅卷排名

image.png

修改个人密码

image.png

查看所有比赛

image.png

以上是智慧校园比赛系统的主要内容

系统部分核心代码:

# -*- coding: utf-8 -*-
from django.contrib.auth.models import User
from django.conf import settings
from django.db import transaction
from django.views.decorators.csrf import csrf_exempt
from account.models import Profile
from business.models import BusinessAccountInfo
from utils.response import json_response
from utils.errors import BizError, UserError
def check_biz(request):
    email = request.GET.get('email', '')  # 获取邮箱
    try:  # 检查数据库中是否由该邮箱注册过的数据
        biz = BusinessAccountInfo.objects.get(email=email)
    except BusinessAccountInfo.DoesNotExist:
        biz = None
    return json_response(200, 'OK', {  # 返回是否已经被注册过和是否已经有此用户
        'userexists': User.objects.filter(email=email).exists(),
        'bizaccountexists': bool(biz)
    })
@csrf_exempt
@transaction.atomic
def registry_biz(request):
    email = request.POST.get('email', '')  # 获取填写的邮箱
    name = request.POST.get('name', '')  # 获取填写的机构名
    username = request.POST.get('username', '')  # 获取填写的机构联系人
    phone = request.POST.get('phone', '')  # 获取填写的手机号
    ctype = request.POST.get('type', BusinessAccountInfo.INTERNET)  # 获取机构类型
    flag = int(request.POST.get('flag', 2))  # 获取一个标记位,代表用户是创建新用户还是使用绑定老用户的方式
    uname = email.split('@')[0]  # 和之前的注册逻辑没什么区别,创建一个账户名
    if not User.objects.filter(username__exact=name).exists():
        final_name = username
    elif not User.objects.filter(username__exact=uname).exists():
        final_name = uname
    else:
        final_name = email
    if flag == 2:  # 如果标记位是2,那么将为他创建新用户
        user = User.objects.create_user(
            username=final_name,
            email=email,
            password=settings.INIT_PASSWORD,
            is_active=False,
            is_staff=False
        )
    if flag == 1:  # 如果标记位是1,那么为他绑定老用户
        try:
            user = User.objects.get(email=email)
        except User.DoesNotExist:
            return json_response(*UserError.UserNotFound)
    pvalues = {
        'phone': phone,
        'name': final_name,
        'user_src': Profile.COMPANY_USER,
    }
    profile, _ = Profile.objects.select_for_update().get_or_create(email=email)  # 获取或创建用户信息
    for k, v in pvalues.items():
        setattr(profile, k, v)
    profile.save()
    bizvalues = {
        'company_name': name,
        'company_username': username,
        'company_phone': phone,
        'company_type': ctype,
    }
    biz, _ = BusinessAccountInfo.objects.select_for_update().get_or_create(  # 获取或创建机构账户信息
        email=email,
        defaults=bizvalues
    )
    return json_response(200, 'OK', {  # 响应JSON格式数据,这个标记位在发送验证邮件的时候还有用
        'name': final_name,
        'email': email,
        'flag': flag
    })
# -*- coding: utf-8 -*-
from __future__ import unicode_literals
from django.db import models
from django.utils.translation import ugettext_lazy as _
from shortuuidfield import ShortUUIDField
from utils.basemodels import CreateUpdateMixin
class BusinessAccountInfo(CreateUpdateMixin):
    """ 出题帐户类 """
    INTERNET = 0
    FINANCE = 1
    ENERGY = 2
    INFRASTRUCTURE = 3
    TRANSPORTATION = 4
    COMMUNICATION = 5
    TYPE_CHOICES = (
        (INTERNET, '互联网'),
        (FINANCE, '金融'),
        (ENERGY, '能源'),
        (INFRASTRUCTURE, '基础建设'),
        (TRANSPORTATION, '交通'),
        (COMMUNICATION, '通信')
    )
    account_id = ShortUUIDField(_(u'出题账户id'), max_length=32, help_text=u'出题账户唯一标识', db_index=True)
    # 帐户信息
    email = models.CharField(_(u'邮箱'), max_length=40, blank=True, null=True, help_text=u'邮箱', db_index=True, unique=True)
    # 公司信息
    company_name = models.CharField(_(u'公司名称'), max_length=60, blank=True, null=True, help_text=u'公司名称')
    company_type = models.IntegerField(_(u'公司类型'), choices=TYPE_CHOICES, default=INTERNET, help_text=u'公司类型')
    company_description = models.TextField(_(u'公司描述'), blank=True, null=True, help_text=u'公司描述')
    company_username = models.CharField(_(u'联系人'), max_length=32, blank=True, null=True, help_text=u'公司联系人')
    company_phone = models.CharField(_(u'联系电话'), max_length=16, blank=True, null=True, help_text=u'公司联系电话', db_index=True)
    company_location = models.TextField(_(u'公司位置'), blank=True, null=True, help_text=u'公司联系地址')
    class Meta:
        verbose_name = _(u'出题账户')
        verbose_name_plural = _(u'出题账户')
    def __unicode__(self):
        return str(self.pk)
    @property
    def data(self):
        return {
            'email': self.email,
            'company_name': self.company_name,
            'company_type': self.company_type,
            'company_location': self.company_location,
            'company_username': self.company_username,
            'company_phone': self.company_phone,
        }
class BusinessAppInfo(CreateUpdateMixin):
    """ 应用信息类 """
    account_id = models.CharField(_(u'出题账户id'), max_length=32, help_text=u'出题账户唯一标识', db_index=True)
    # APP 配置信息
    app_id = ShortUUIDField(_(u'应用id'), max_length=32, help_text=u'应用唯一标识', db_index=True)
    app_name = models.CharField(_(u'应用名'), max_length=40, blank=True, null=True, help_text=u'应用名')
    app_description = models.TextField(_(u'应用描述'), blank=True, null=True, help_text=u'应用描述')
    class Meta:
        verbose_name = _(u'应用信息')
        verbose_name_plural = _(u'应用信息')
    def __unicode__(self):
        return str(self.pk)
    @property
    def data(self):
        return {
            'app_id': self.app_id,
            'app_name': self.app_name,
            'account_id': self.account_id,
        }
class AppConfigInfo(CreateUpdateMixin):
    """ 应用配置信息类 """
    app_id = models.CharField(_(u'应用id'), max_length=32, help_text=u'应用唯一标识', db_index=True)
    app_name = models.CharField(_(u'应用名'), max_length=40, blank=True, null=True, help_text=u'应用名')
    # 文案配置
    rule_text = models.TextField(_(u'比赛规则'), max_length=255, blank=True, null=True, help_text=u'比赛规则')
    # 显示信息
    is_show_userinfo = models.BooleanField(_(u'展示用户表单'), default=False, help_text=u'是否展示用户信息表单')
    userinfo_fields = models.CharField(_(u'用户表单字段'), max_length=128, blank=True, null=True, help_text=u'需要用户填写的字段#隔开')
    userinfo_field_names = models.CharField(_('用户表单label'), max_length=128, blank=True, null=True, help_text=u'用户需要填写的表单字段label名称')
    option_fields = models.CharField(_(u'下拉框字段'), max_length=128, blank=True, null=True, help_text=u'下拉框字段选项配置,#号隔开,每个字段由:h和,号组成。 如 option1:吃饭,喝水,睡觉#option2:上班,学习,看电影')
    class Meta:
        verbose_name = _(u'应用配置信息')
        verbose_name_plural = _(u'应用配置信息')
    def __unicode__(self):
        return str(self.pk)
    # 页面配置数据
    @property
    def show_info(self):
        return {
            'is_show_userinfo': self.is_show_userinfo,
            'userinfo_fields': self.userinfo_fields,
            'userinfo_field_names': self.userinfo_field_names,
            'option_fields': self.option_fields,
        }
    @property
    def text_info(self):
        return {
            'rule_text': self.rule_text,
        }
    @property
    def data(self):
        return {
            'show_info': self.show_info,
            'text_info': self.text_info,
            'app_id': self.app_id,
            'app_name': self.app_name
        }
class UserInfoImage(CreateUpdateMixin):
    """
    用户表单图片配置类
    """
    uii_name = models.CharField(_(u'配置名称'), max_length=32, blank=True, null=True, help_text=u'信息图片配置名称')
    # 用户信息
    name = models.CharField(_(u'姓名'), max_length=60, blank=True, null=True, help_text=u'姓名')
    sex = models.CharField(_(u'性别'), max_length=60, blank=True, null=True, help_text=u'性别')
    age = models.CharField(_(u'年龄'), max_length=60, blank=True, null=True, help_text=u'年龄')
    phone = models.CharField(_(u'手机号'), max_length=60, blank=True, null=True, help_text=u'电话')
    wxid = models.CharField(_(u'微信号'), max_length=60, blank=True, null=True, help_text=u'微信号')
    email = models.CharField(_(u'邮箱'), max_length=60, blank=True, null=True, help_text=u'邮箱')
    pid = models.CharField(_(u'身份证号'), max_length=60, blank=True, null=True, help_text=u'身份证号')
    graduated_from = models.CharField(_(u'毕业院校'), max_length=60, blank=True, null=True, help_text=u'毕业院校')
    address = models.CharField(_(u'地址'), max_length=60, blank=True, null=True, help_text=u'联系地址')
    resume = models.CharField(_(u'简历'), max_length=60, blank=True, null=True, help_text=u'简历')
    class Meta:
        verbose_name = _(u'用户信息图片配置')
        verbose_name_plural = _(u'用户信息图片配置')
    def __unicode__(self):
        return str(self.pk)
    @property
    def data(self):
        return {
            'name': self.name,
            'sex': self.sex,
            'age': self.age,
            'phone': self.phone,
            'wxid': self.wxid,
            'email': self.email,
            'pid': self.pid,
            'graduated_from': self.graduated_from,
            'address': self.address,
        }
class UserInfoRegex(CreateUpdateMixin):
    """
    用户正则表达式配置类
    """
    field_name = models.CharField(_(u'字段名'), max_length=16, blank=True, null=True, help_text=u'字段名')
    regex = models.CharField(_(u'正则表达式值'), max_length=40, blank=True, null=True, help_text=u'正则表达式')
    description = models.CharField(_(u'description'), max_length=40, blank=True, help_text=u'错误描述')
    class Meta:
        verbose_name = _(u'用户信息字段正则表达式')
        verbose_name_plural = _(u'用户信息字段正则表达式')
    def __unicode__(self):
        return self.field_name
    @property
    def data(self):
        return {
            'field_name': self.field_name,
            'regex': self.regex,
            'description': self.description,
        }
# -*- coding: utf-8 -*-
from django.contrib import admin
from competition.models import (BankInfo, ChoiceInfo, CompetitionKindInfo,
                                CompetitionQAInfo, FillInBlankInfo)
class CompetitionKindInfoAdmin(admin.ModelAdmin):
    """
    比赛信息后台
    """
    list_display = ('kind_id', 'account_id', 'app_id', 'bank_id', 'kind_name', 'total_score', 'question_num', 'total_partin_num', 'status', 'created_at', 'updated_at')
    list_filter = ('account_id', 'status')
    search_fields = ('kind_name', 'kind_id', 'app_id', 'account_id',)
    readonly_fields = ('kind_id', 'total_partin_num',)
    def save_model(self, request, obj, form, change):
        obj.save()
    def delete_model(self, request, obj):
        obj.delete()
    def get_readonly_fields(self, request, obj=None):
        return self.readonly_fields
class BankInfoAdmin(admin.ModelAdmin):
    """
    题库后台配置
    """
    list_display = ('bank_id', 'bank_type', 'kind_num', 'choice_num', 'fillinblank_num', 'partin_num')
    list_filter = ('bank_type', 'bank_id',)
    search_fields = ('bank_id',)
    readonly_fields = ('bank_id', 'choice_num', 'fillinblank_num', 'kind_num', 'partin_num')
    def save_model(self, request, obj, form, change):
        obj.choice_num = ChoiceInfo.objects.filter(bank_id=obj.bank_id).count()
        obj.fillinblank_num = FillInBlankInfo.objects.filter(bank_id=obj.bank_id).count()
        obj.save()
class ChoiceInfoAdmin(admin.ModelAdmin):
    """
    选择题配置后台
    """
    list_display = ('bank_id', 'question', 'answer', 'item1', 'item2', 'item3', 'item4', 'source', 'status', 'created_at', 'updated_at')
    list_filter = ('bank_id', 'status')
    search_fields = ('bank_id', 'question', 'answer', 'item1', 'item2', 'item3', 'item4')
    def save_model(self, request, obj, form, change):
        obj.save()
    def delete_model(self, request, obj):
        obj.delete()
class FillInBlankInfoAdmin(admin.ModelAdmin):
    """
    填空题配置后台
    """
    list_display = ('bank_id', 'question', 'answer', 'source', 'status', 'created_at', 'updated_at')
    list_filter = ('bank_id', 'status')
    search_fields = ('bank_id', 'question', 'answer')
class CompetitionQAInfoAdmin(admin.ModelAdmin):
    """
    答题记录信息后台
    """
    list_display = ('kind_id', 'status', 'uid', 'qa_id', 'score', 'created_at', 'updated_at')
    list_filter = ('kind_id', 'uid', 'qa_id', 'started', 'finished', 'status')
    search_fields = ('uid', 'kind_id', )
    readonly_fields = ('qa_id',)
admin.site.register(CompetitionKindInfo, CompetitionKindInfoAdmin)
admin.site.register(CompetitionQAInfo, CompetitionQAInfoAdmin)
admin.site.register(ChoiceInfo, ChoiceInfoAdmin)
admin.site.register(FillInBlankInfo, FillInBlankInfoAdmin)
admin.site.register(BankInfo, BankInfoAdmin)
相关文章
|
3月前
|
机器学习/深度学习 监控 算法
基于mediapipe深度学习的手势数字识别系统python源码
本内容涵盖手势识别算法的相关资料,包括:1. 算法运行效果预览(无水印完整程序);2. 软件版本与配置环境说明,提供Python运行环境安装步骤;3. 部分核心代码,完整版含中文注释及操作视频;4. 算法理论概述,详解Mediapipe框架在手势识别中的应用。Mediapipe采用模块化设计,包含Calculator Graph、Packet和Subgraph等核心组件,支持实时处理任务,广泛应用于虚拟现实、智能监控等领域。
|
28天前
|
安全 JavaScript Java
Python中None与NoneType的真相:从单例对象到类型系统的深度解析
本文通过10个真实场景,深入解析Python中表示“空值”的None与NoneType。从单例模式、函数返回值,到类型注解、性能优化,全面揭示None在语言设计与实际编程中的核心作用,帮助开发者正确高效地处理“无值”状态,写出更健壮、清晰的Python代码。
126 3
|
2月前
|
算法 数据可视化 数据挖掘
基于EM期望最大化算法的GMM参数估计与三维数据分类系统python源码
本内容展示了基于EM算法的高斯混合模型(GMM)聚类实现,包含完整Python代码、运行效果图及理论解析。程序使用三维数据进行演示,涵盖误差计算、模型参数更新、结果可视化等关键步骤,并附有详细注释与操作视频,适合学习EM算法与GMM模型的原理及应用。
|
3月前
|
Linux 数据库 数据安全/隐私保护
Python web Django快速入门手册全栈版,共2590字,短小精悍
本教程涵盖Django从安装到数据库模型创建的全流程。第一章介绍Windows、Linux及macOS下虚拟环境搭建与Django安装验证;第二章讲解项目创建、迁移与运行;第三章演示应用APP创建及项目汉化;第四章说明超级用户创建与后台登录;第五章深入数据库模型设计,包括类与表的对应关系及模型创建步骤。内容精炼实用,适合快速入门Django全栈开发。
104 1
|
前端开发 关系型数据库 MySQL
基于python“花开富贵”花园管理系统
感谢大学同学的陪伴与帮助,在我独立编写毕业论文期间,大学同学的鼓励与耐心的帮助使得我少走很多弯路,节省毕业论文的编写时间,也让我有更多精力去完善我开发的系统。 在整个系统开发过程中,我周围的同学和朋友给了我很多意见,所以我很快就确认了系统的商业思想。在次,我由衷的向他们表示感激。
35 0
|
5月前
|
前端开发 JavaScript 关系型数据库
基于python的租房网站-房屋出租租赁系统(python+django+vue)源码+运行
该项目是基于python/django/vue开发的房屋租赁系统/租房平台,作为本学期的课程作业作品。欢迎大家提出宝贵建议。
158 6
|
10月前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
598 45
|
12月前
|
机器学习/深度学习 人工智能 算法
植物病害识别系统Python+卷积神经网络算法+图像识别+人工智能项目+深度学习项目+计算机课设项目+Django网页界面
植物病害识别系统。本系统使用Python作为主要编程语言,通过收集水稻常见的四种叶片病害图片('细菌性叶枯病', '稻瘟病', '褐斑病', '稻瘟条纹病毒病')作为后面模型训练用到的数据集。然后使用TensorFlow搭建卷积神经网络算法模型,并进行多轮迭代训练,最后得到一个识别精度较高的算法模型,然后将其保存为h5格式的本地模型文件。再使用Django搭建Web网页平台操作界面,实现用户上传一张测试图片识别其名称。
400 22
植物病害识别系统Python+卷积神经网络算法+图像识别+人工智能项目+深度学习项目+计算机课设项目+Django网页界面
|
12月前
|
机器学习/深度学习 算法 TensorFlow
交通标志识别系统Python+卷积神经网络算法+深度学习人工智能+TensorFlow模型训练+计算机课设项目+Django网页界面
交通标志识别系统。本系统使用Python作为主要编程语言,在交通标志图像识别功能实现中,基于TensorFlow搭建卷积神经网络算法模型,通过对收集到的58种常见的交通标志图像作为数据集,进行迭代训练最后得到一个识别精度较高的模型文件,然后保存为本地的h5格式文件。再使用Django开发Web网页端操作界面,实现用户上传一张交通标志图片,识别其名称。
455 7
交通标志识别系统Python+卷积神经网络算法+深度学习人工智能+TensorFlow模型训练+计算机课设项目+Django网页界面

热门文章

最新文章

推荐镜像

更多