可自己做题库随机出题的app

在如今这个数字化时代,越来越多的教育机构和个人开始使用app来进行教学和学习。其中比较常见的就是一些做题类app。许多人都很好奇,在背后这些app是如何实现随机出题的呢?本篇文章将介绍一种可自己做题库随机出题的app的原理和详细介绍。

1. 原理介绍

一、数据存储

做题库随机出题app的实现必须要首先有做题库的数据存储。有很多种数据存储方式,包括MySQL、mongodb、redis等等。在这里,我们使用MySQL作为数据库进行数据库操作。将我们所需的题目题干、题目选项、题目答案等信息存储到MySQL数据库中,随时可以调用使用。

二、随机抽取

做题库随机出题app的另一个重要部分就是“随机抽取”,即从数据库中随机抽取学生需要给出答案的题目。在随机抽取过程中,我们需要配置一些参数来确定抽取多少道题目、抽取题目的类型和难易程度等。

三、展示界面

做题库随机出题app的最后一步就是展示界面。需要将我们所随机抽取的题目展示出来,并且获取学生的答案进行判断。展示界面主要包含题目展示、选项展示、答案展示、答案正确性确认等方面。

2. 详细介绍

接下来,我们就可以详细地介绍一下,如何使用MySQL数据库实现做题库随机出题app。

一、数据存储

在数据库中,我们需要先创建一个表来存储题目的信息。表中应该包括题目ID、题干、选项A、选项B、选项C、选项D、答案等字段(可根据实际需要增加、减少字段)。

```sql

CREATE TABLE IF NOT EXISTS `questions` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`stem` varchar(100) COLLATE utf8_unicode_ci NOT NULL COMMENT '问题题干',

`choice_a` varchar(100) COLLATE utf8_unicode_ci DEFAULT NULL COMMENT '选项A',

`choice_b` varchar(100) COLLATE utf8_unicode_ci DEFAULT NULL COMMENT '选项B',

`choice_c` varchar(100) COLLATE utf8_unicode_ci DEFAULT NULL COMMENT '选项C',

`choice_d` varchar(100) COLLATE utf8_unicode_ci DEFAULT NULL COMMENT '选项D',

`answer` varchar(20) COLLATE utf8_unicode_ci NOT NULL COMMENT '问题答案',

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci COMMENT='问题表';

```

二、存储数据

将存储好的题目信息放到一个外面的文件里,这里我们用json格式文件,这个文件的本地路径是question_bank.json。其中,每个问题由题目stem、选项choice与答案answer三个字段组成,要注意的是answer字段中是记录正确答案的。

```json

[

{

"stem": "我国对外开放的首倡者和开创者是:",

"choice_a": "邓小平",

"choice_b": "邓颖超",

"choice_c": "陈毅",

"choice_d": "周恩来",

"answer": "a"

},

{

"stem": "下列地理位置最偏远的城市是:",

"choice_a": "拉萨",

"choice_b": "哈尔滨",

"choice_c": "三亚",

"choice_d": "乌鲁木齐",

"answer": "d"

},

{

"stem": "中国通用的地理经度基准线是什么?",

"choice_a": "东经110°",

"choice_b": "东经108°",

"choice_c": "东经105°",

"choice_d": "东经120°",

"answer": "b"

}

]

```

下面的代码演示了如何将json格式的数据存入到MySQL数据库中。

```python

import json

import pymysql

def save_data2mysql(conn, data, tb_name):

if len(data)>0:

cur = conn.cursor()

sql_create_tb = '''

CREATE TABLE IF NOT EXISTS `''' + tb_name + '''` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`stem` varchar(200) NOT NULL COMMENT '问题题干',

`choice_a` varchar(100) DEFAULT NULL COMMENT '选项A',

`choice_b` varchar(100) DEFAULT NULL COMMENT '选项B',

`choice_c` varchar(100) DEFAULT NULL COMMENT '选项C',

`choice_d` varchar(100) DEFAULT NULL COMMENT '选项D',

`answer` varchar(10) NOT NULL COMMENT '问题答案',

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT=''' + tb_name + '''';

'''

cur.execute(sql_create_tb)

conn.commit()

sql_insert = '''INSERT INTO `''' + tb_name + '''`

(`stem`, `choice_a`, `choice_b`, `choice_c`, `choice_d`, `answer`)

VALUES (%s,%s,%s,%s,%s,%s)'''

for item in data:

cur.execute(sql_insert, (item['stem'], item['choice_a'], item['choice_b'], item['choice_c'], item['choice_d'], item['answer']))

conn.commit()

cur.close()

if __name__ == '__main__':

dbName = 'test' # 数据库名

tbName = 'questions' # 数据表名

# 配置数据库连接信息

conn = pymysql.connect(

host='127.0.0.1',

user='root',

passwd='root',

db=dbName,

port=3306,

charset='utf8mb4')

# 开始存储数据

with open('question_bank.json', 'r') as f:

data = json.load(f)

save_data2mysql(conn, data, tbName)

```

三、随机抽取和展示题目

操作MySQL数据库后,我们就可以根据学生所需抽取的题目的数量和类型等参数,从MySQL中随机抽取题目。接下来的代码演示了如何实现从MySQL数据库中随机抽取题目。并同时将这些题目封装成一个函数帮助我们在app中随时调用。

```python

import random

import pymysql

def get_questions(qtb_name, num_per_choice, choices):

'''

从数据库qtb_name中获取num_per_choice个题目,

每个题目的答案类型必须在choices所代表的答案类型中

'''

db = pymysql.connect("localhost", "user", "password", "dbname")

cursor = db.cursor()

questions = [] # 获取的题目

for choice in choices:

sql = '''

SELECT `stem`, `choice_a`, `choice_b`, `choice_c`, `choice_d`, `answer`

FROM `''' + qtb_name + '''` WHERE `answer`="%s" ORDER BY RAND() LIMIT %d;

''' % (choice, num_per_choice)

try:

cursor.execute(sql)

results = cursor.fetchall()

for row in results:

question = {}

question['stem'] = row[0]

question['choices'] = [row[1], row[2], row[3], row[4]]

question['answer'] = row[5]

questions.append(question)

except:

print("Error: select question list failed!")

db.close()

# 让每个题目随机排列

for question in questions:

question['choices'].append(question['answer']) # 选项中加入答案

random.shuffle(question['choices']) # 随机排列选项,使A、B、C、D的位置不固定

return questions

```

在获取到随机抽取的题目列表后,我们就可以在展示界面中展示出来,并根据学生所输入的答案判断正误。接下来的代码演示了如何封装一个函数用于展示随机抽题的题目并获取用户提交的答案。函数中以问题列表questions作为参数,其中每条问题的格式为{stem:'', choices:[choice_a, choice_b, choice_c, choice_d, correct], answer:''}。其中stem和choices都是字符串。

```python

import tkinter as tk

class QuizUI:

def __init__(self, master, stem, choices):

self.master = master

self.stem_canvas = tk.Canvas(self.master, width=480, height=50)

self.choice_canvas = tk.Canvas(self.master, width=480, height=240)

self.check_button = tk.Button(self.master, text="确认", command=self.check_answer)

self.show_results = tk.Label(self.master, text=" ", font=('Arial', 14))

# 设置题干

self.stem_canvas.create_text(240, 30, text=stem, font=('Arial', 16), width=460, justify='center')

self


相关知识:
自建题库出卷的app
自建题库出卷的app是一种教育类的应用程序,它允许用户创建自己的题库,然后从题库中选择题目来生成试卷。这种应用程序通常包含以下几个模块:题库管理模块、试卷生成模块、考试管理模块等。在题库管理模块中,用户可以创建、编辑、查看和删除题目。用户可以根据题目类型(
2023-06-05
自己做试题的app
随着移动互联网时代的到来,人们对手机APP的需求也越来越高。而自己做试题的APP也越来越受到大众的欢迎,尤其是学生群体。自己做试题的APP可以帮助学生们更好地进行自我测试,并且获取更多的学习经验。下面,我将介绍一下自己做试题的APP的原理和详细内容。自己做
2023-06-05
自己做个聊天app有什么用
聊天app是现在人们日常生活中必不可少的一部分,可以通过聊天app和朋友,家人或同事交流沟通。但是,跟着手机app的激增和大型社交媒体平台的崛起,在市场上只推出一个新的聊天app显然面临很大的竞争压力。那么,自己做一个聊天app真的有什么用呢?首先,自己做
2023-06-05
自己做个软件app难吗
自己做个软件APP并不是很难,只要有一定的编程经验,掌握了一些基础知识和技能,就可以去尝试开发自己的APP了。下面是具体的一些原理和步骤介绍:1.明确需求,选择合适的开发工具在开发一款软件APP时,首先需要明确需求,考虑用户群体和使用场景。然后根据需求选择
2023-06-05
自制app免费制作
如今,移动应用程序是现代社会普及使用的主要方式之一,让我们与朋友保持联系,帮助我们管理时间和任务、获取新闻、研究课程和更多其他操作。与此同时,许多人有自己的想法和概念来开发他们自己的移动应用程序,但他们通常不清楚自制app的制作原理。在本文中,我们将详细介
2023-06-05
自主开发app怎么上架
自主开发App是一项非常复杂的工作,App的上架是开发者最终得到产出的重要一环。下面是关于自主开发App如何上架的详细介绍。1.申请开发者账号在App Store和Google Play上架App必须要先注册开发者账号。注册的过程非常简单,只需要提交一些基
2023-06-05
自己能制作汽车外观改装的app
想要制作一款汽车外观改装app,需要了解以下原理:1. 目标用户和市场定位:在制作app之前,需要确定目标用户和市场定位。比如说,你的目标用户是汽车改装爱好者,市场定位在汽车改装领域。2. 功能设计:设计app的功能,这些功能要满足目标用户的需求。开发应该
2023-06-05
自己如何制作电商app软件
制作电商APP软件的过程可以分为5个主要步骤:设计、开发、测试、发布和营销。下面将介绍每个步骤的原理和详细步骤。第一步:设计在设计阶段,需要确定APP的目标用户、商业模式和功能。首先,需要了解目标用户的需求和偏好,来决定APP的定位和功能。然后,需要确定商
2023-06-05
中国石油app怎么自己开发票
中国石油是一家国有大型能源公司,拥有广泛的投资领域和多个子公司。为了方便消费者,中国石油APP提供了便捷的开具发票服务。下面详细介绍中国石油APP自己开具发票的原理和步骤。一、开具发票原理中国石油APP开具发票的原理是将消费者的购买信息与发票信息通过APP
2023-06-05
招生app软件自己怎么做出来的
招生app软件的开发主要分为以下几个步骤:1. 需求分析和规划在开发招生app软件之前,需要先明确软件的目的、功能、用户需求、市场需求等,建立完整的规划和需求分析文档。这样可以确保软件在开发过程中不偏离方向,最终达成用户的期望。2. UI设计UI(User
2023-06-05
记账app开发自学教程
随着互联网普及和技术的日益发展,记账app逐渐成为广大群众管理个人财务的必备工具之一。在这样一个背景下,学习一门记账app开发自然成为很多人关注的一个话题。本篇文章将从原理和详细介绍两个方面来介绍记账app开发的自学教程。一、原理记账app的原理其实非常简
2023-05-30
安卓app编程开发自学教程
安卓App编程开发已经成为了现代IT行业最为重要的领域之一,而且由于其广泛的应用,平均工资也相当不错。因此,如果你对于计算机编程和App开发有着浓厚的兴趣,那么学习安卓应用编程开发将是一个非常好的选择。下面,我们将会通过原理和详细介绍两部分,为读者带来一个
2023-05-30
©2015-2021 自建app开发平台 www.appbyme.cn 蜀ICP备17005078号-1