可自己做题库随机出题的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


相关知识:
自由appleapp开发
自由Apple App开发是指开发者可以使用自己的代码和工具创建并发布iOS应用程序,而不必遵守苹果的开发规定和限制。这项技术是通过越狱工具来实现的。越狱是指对iOS系统进行破解,移除苹果的限制,可以让用户下载、安装并使用不在App Store上的应用程序
2023-06-05
自己做手机app多少钱
当今,手机成为人们生活必备品之一,而手机应用程序(APP)也越来越受到人们的关注。如果你也有创新的想法,想要开发出自己的手机APP,那么不妨了解一下自己做手机APP的成本。一、APP开发步骤1.初期规划:确定APP的目的、功能、特点等元素,并绘制原型图。2
2023-06-05
自己做室内装饰设计的app
现在,人们对房屋的装饰需求日益增长,尤其是对于室内装饰的需求,因此室内装饰设计App越来越受欢迎。自己做一个室内装饰设计App,是一个令人惊奇的想法。下面将介绍这个App的原理及详细介绍。原理App的构建总体上涉及到以下几个部分:用户需求分析:在开始任何应
2023-06-05
自己设计制作app
制作一个app,首先需要明确两个问题:想要做出什么样的app?使用哪种技术进行开发?一、想要做出什么样的app?1.明确app的类型和功能在开始设计app之前,你需要确认你的app将要提供哪些服务或功能。这一步相当于你的定义,可以从你的idea入手,把它拆
2023-06-05
自己想开发一个app怎么弄
如果你想开发自己的手机应用程序,可以参考下面的步骤:第一步:确定你的应用创意首先,需要确定自己的应用创意,想清楚需要开发什么样的应用,需要解决什么问题,或提供什么服务。然后,需要研究市场上有哪些类似的应用,以了解用户需求和市场定位。确定了应用的主要功能和特
2023-06-05
自己开发app应用市场安全吗
自己开发app应用市场是否安全,需要从技术和法律两个方面来进行考虑。从技术方面来看,自己开发app应用市场是安全的,前提是需要严格遵守应用市场的安全规范,确保平台的安全性。需要考虑以下几个方面:1.用户数据安全:尽可能采用加密算法、防重放攻击算法等技术手段
2023-06-05
制作app怎么自定义键盘
在制作app时,许多开发人员会涉及到自定义键盘的需求,例如数字键盘、表情包键盘等。这篇文章将介绍在iOS平台上,制作自定义键盘的原理和具体实现方法。一、原理介绍在iOS平台上,自定义键盘的原理基于 UIResponder 和 inputView。UIVie
2023-06-05
我想自己做个app软件可以吗
当今时代的移动设备已经成为人们日常生活中不可或缺的一部分。加之互联网的快速发展和智能手机、平板电脑等移动设备的普及,越来越多的人开始喜欢使用APP软件来帮助他们解决问题。因此,自己制作一款符合自己需求的APP软件也变得越来越流行。下面,我将向大家介绍如何制
2023-05-31
如何做到自律的app
随着移动设备越来越普及,人们越来越依赖手机和平板电脑来浏览网站、浏览社交媒体、玩游戏、看视频等。这些应用程序极易让人分散注意力,导致人们变得缺乏自律,无法集中注意力完成重要任务。针对这一问题,出现了很多治愈系自律APP。自律APP可以帮助用户更好地管理他们
2023-05-30
可以自己制作铃声的app
随着移动设备的普及,手机铃声已经成为我们日常生活的必备。在市场上,有很多铃声制作软件,但这些软件往往需要一定的技术水平才能使用。为了让更多的人能够自己制作铃声,下面详细介绍一下制作铃声的原理和制作方法。对于移动设备上的铃声,实际上是一种音频文件,格式可以是
2023-05-30
广东自动量化交易app开发价格
自动量化交易指利用程序化交易算法进行交易的一种方式,也被称为机器人交易或智能交易。广东自动量化交易App开发的价格因开发公司和开发功能的不同而异,一般在10万-50万之间。广东自动量化交易App的开发原理是基于量化交易策略的自动化执行,人们可以编写交易策略
2023-05-30
app制作自己用
移动应用程序的出现早已不是新闻,app已经成为几乎每个人在日常生活中不可或缺的一部分。然而,很少有人知道如何制作自己的app。怎样才能在没有编程经验的情况下制作自己的app呢?本文将会提供一些简单的方法,帮助读者了解app制作的原理以及基本的步骤。第一步:
2023-05-30
©2015-2021 自建app开发平台 www.appbyme.cn 蜀ICP备17005078号-1