搭建一个考试系统,使其具有自动判卷,查询,统计等功能,代码书写

时间: 2023-10-16 11:09:51 浏览: 50
这是一个比较复杂的项目,需要设计合理的数据库结构和后端逻辑,以下是一个简单的代码示例: 1. 数据库设计 考试系统需要存储考生信息、试题信息、考试记录等数据,因此需要设计相应的表结构。这里给出一个简化的表结构示例: ``` CREATE TABLE `user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(50) NOT NULL, `password` varchar(50) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `exam` ( `id` int(11) NOT NULL AUTO_INCREMENT, `title` varchar(100) NOT NULL, `start_time` datetime NOT NULL, `end_time` datetime NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `question` ( `id` int(11) NOT NULL AUTO_INCREMENT, `exam_id` int(11) NOT NULL, `content` text NOT NULL, `answer` text NOT NULL, PRIMARY KEY (`id`), KEY `exam_id` (`exam_id`), CONSTRAINT `question_ibfk_1` FOREIGN KEY (`exam_id`) REFERENCES `exam` (`id`) ON DELETE CASCADE ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `record` ( `id` int(11) NOT NULL AUTO_INCREMENT, `user_id` int(11) NOT NULL, `exam_id` int(11) NOT NULL, `score` int(11) NOT NULL, `submit_time` datetime NOT NULL, PRIMARY KEY (`id`), KEY `user_id` (`user_id`), KEY `exam_id` (`exam_id`), CONSTRAINT `record_ibfk_1` FOREIGN KEY (`user_id`) REFERENCES `user` (`id`) ON DELETE CASCADE ON UPDATE CASCADE, CONSTRAINT `record_ibfk_2` FOREIGN KEY (`exam_id`) REFERENCES `exam` (`id`) ON DELETE CASCADE ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8; ``` 2. 后端代码 接下来是后端代码的示例,使用了Python的Flask框架: ```python from flask import Flask, jsonify, request from flask_sqlalchemy import SQLAlchemy app = Flask(__name__) app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://username:password@hostname/database' db = SQLAlchemy(app) class User(db.Model): id = db.Column(db.Integer, primary_key=True) name = db.Column(db.String(50), nullable=False) password = db.Column(db.String(50), nullable=False) class Exam(db.Model): id = db.Column(db.Integer, primary_key=True) title = db.Column(db.String(100), nullable=False) start_time = db.Column(db.DateTime, nullable=False) end_time = db.Column(db.DateTime, nullable=False) class Question(db.Model): id = db.Column(db.Integer, primary_key=True) exam_id = db.Column(db.Integer, db.ForeignKey('exam.id', ondelete='CASCADE'), nullable=False) content = db.Column(db.Text, nullable=False) answer = db.Column(db.Text, nullable=False) class Record(db.Model): id = db.Column(db.Integer, primary_key=True) user_id = db.Column(db.Integer, db.ForeignKey('user.id', ondelete='CASCADE'), nullable=False) exam_id = db.Column(db.Integer, db.ForeignKey('exam.id', ondelete='CASCADE'), nullable=False) score = db.Column(db.Integer, nullable=False) submit_time = db.Column(db.DateTime, nullable=False) @app.route('/login', methods=['POST']) def login(): data = request.get_json() user = User.query.filter_by(name=data['name'], password=data['password']).first() if user: return jsonify({'result': 'success'}) else: return jsonify({'result': 'failure'}) @app.route('/exam', methods=['GET']) def get_exams(): exams = Exam.query.all() result = [{'id': exam.id, 'title': exam.title, 'start_time': exam.start_time, 'end_time': exam.end_time} for exam in exams] return jsonify(result) @app.route('/exam/<int:exam_id>/question', methods=['GET']) def get_questions(exam_id): questions = Question.query.filter_by(exam_id=exam_id).all() result = [{'id': question.id, 'content': question.content} for question in questions] return jsonify(result) @app.route('/exam/<int:exam_id>/submit', methods=['POST']) def submit_exam(exam_id): data = request.get_json() user_id = data['user_id'] answers = data['answers'] questions = Question.query.filter_by(exam_id=exam_id).all() score = 0 for i, question in enumerate(questions): if question.answer == answers[i]: score += 1 record = Record(user_id=user_id, exam_id=exam_id, score=score, submit_time=datetime.now()) db.session.add(record) db.session.commit() return jsonify({'result': 'success', 'score': score}) if __name__ == '__main__': app.run() ``` 3. 前端界面 最后是前端界面的示例,使用了Bootstrap框架: ```html <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>考试系统</title> <link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css"> <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script> <script src="https://cdn.bootcss.com/bootstrap/3.3.7/js/bootstrap.min.js"></script> </head> <body> <div class="container"> <h1>考试系统</h1> <form id="login-form"> <div class="form-group"> <label for="name">用户名</label> <input type="text" class="form-control" id="name" name="name"> </div> <div class="form-group"> <label for="password">密码</label> <input type="password" class="form-control" id="password" name="password"> </div> <button type="submit" class="btn btn-primary">登录</button> </form> <hr> <div id="exam-list"> <h2>考试列表</h2> <table class="table table-striped"> <thead> <tr> <th>#</th> <th>标题</th> <th>开始时间</th> <th>结束时间</th> <th>操作</th> </tr> </thead> <tbody> </tbody> </table> </div> <div id="question-list"> <h2>试题列表</h2> <div class="panel-group" id="accordion"> </div> <button type="button" class="btn btn-primary" id="submit-btn" style="display: none;">提交</button> </div> </div> <script> $(function() { $('#login-form').submit(function(event) { event.preventDefault(); var name = $('#name').val(); var password = $('#password').val(); $.ajax({ url: '/login', type: 'POST', dataType: 'json', data: JSON.stringify({name: name, password: password}), contentType: 'application/json', success: function(data) { if (data.result == 'success') { loadExams(); } else { alert('登录失败'); } }, error: function() { alert('网络错误'); } }); }); function loadExams() { $.get('/exam', function(data) { var tbody = $('#exam-list table tbody'); tbody.empty(); for (var i = 0; i < data.length; i++) { var exam = data[i]; var tr = $('<tr></tr>'); tr.append($('<td></td>').text(exam.id)); tr.append($('<td></td>').text(exam.title)); tr.append($('<td></td>').text(exam.start_time)); tr.append($('<td></td>').text(exam.end_time)); var td = $('<td></td>'); var button = $('<button></button>').text('开始考试').addClass('btn btn-primary'); button.click(function(exam_id) { return function() { loadQuestions(exam_id); } }(exam.id)); td.append(button); tr.append(td); tbody.append(tr); } }); } function loadQuestions(exam_id) { $.get('/exam/' + exam_id + '/question', function(data) { var accordion = $('#accordion'); accordion.empty(); for (var i = 0; i < data.length; i++) { var question = data[i]; var panel = $('<div></div>').addClass('panel panel-default'); var heading = $('<div></div>').addClass('panel-heading'); var title = $('<h4></h4>').addClass('panel-title'); var link = $('<a></a>').attr('data-toggle', 'collapse').attr('data-parent', '#accordion') .attr('href', '#collapse' + i).text(question.content); title.append(link); heading.append(title); panel.append(heading); var body = $('<div></div>').addClass('panel-collapse collapse').attr('id', 'collapse' + i); var inner = $('<div></div>').addClass('panel-body'); inner.append($('<textarea></textarea>').addClass('form-control').attr('rows', '5').attr('name', 'answer-' + i)); body.append(inner); panel.append(body); accordion.append(panel); } $('#submit-btn').show(); $('#submit-btn').unbind('click').click(function() { submitExam(exam_id); }); }); } function submitExam(exam_id) { var answers = []; $('#question-list textarea').each(function() { answers.push($(this).val()); }); $.ajax({ url: '/exam/' + exam_id + '/submit', type: 'POST', dataType: 'json', data: JSON.stringify({user_id: 1, answers: answers}), contentType: 'application/json', success: function(data) { alert('得分:' + data.score); }, error: function() { alert('网络错误'); } }); } loadExams(); }); </script> </body> </html> ``` 以上代码仅供参考,实际项目还需要进一步完善和优化。

相关推荐

最新推荐

recommend-type

Python开发之快速搭建自动回复微信公众号功能

主要介绍了Python开发之快速搭建自动回复微信公众号功能的相关资料,需要的朋友可以参考下
recommend-type

在Ubuntu上搭建一个基于webrtc的多人视频聊天服务实例代码详解

主要介绍了在Ubuntu上搭建一个基于webrtc的多人视频聊天服务,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
recommend-type

超详细的Web自动化测试环境搭建(Python+Selenium+Webdriver)

1. Web自动化测试环境如下: 脚本语言:Python 3.x 开发工具:PyCharm 自动化测试框架:Selenium 3.x 浏览器及对应驱动:Firefox(geckodriver.exe)或者Chrome(chromedriver.exe) 系统环境:windows10 2. 环境...
recommend-type

从零开始搭建一个react项目开发

主要介绍了从零开始搭建一个react项目开发,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
recommend-type

Python+Selenium实现自动化的环境搭建的步骤(图文)

驱动的两个下载地址: http://chromedriver.storage.googleapis.com/index.html http://npm.taobao.org/mirrors/chromedriver/ a.先找到浏览器的版本 b.找到与浏览器对应的驱动 c.把下载好的驱动放到python...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

2. 通过python绘制y=e-xsin(2πx)图像

可以使用matplotlib库来绘制这个函数的图像。以下是一段示例代码: ```python import numpy as np import matplotlib.pyplot as plt def func(x): return np.exp(-x) * np.sin(2 * np.pi * x) x = np.linspace(0, 5, 500) y = func(x) plt.plot(x, y) plt.xlabel('x') plt.ylabel('y') plt.title('y = e^{-x} sin(2πx)') plt.show() ``` 运行这段
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。