可自己做题库随机出题的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需要考虑的因素有很多,包括功能、技术、设计、测试等等。成本也因此而异,下面将详细介绍开发公司锁客app的成本和原理。一、功能需求公司锁客app需要具备哪些功能,不同的功能会影响开发成本。基本功能包括管理锁的状态、授权锁的使用权、限制授
2023-06-05
自己做饭的软件app
饮食是人们日常生活中非常重要的部分,随着人们对于饮食要求的提高,吃得健康、方便、美味也就变得尤为重要。在这个背景下,自己做饭的软件app应运而生。自己做饭的软件app实际上是一种提供美食食谱、菜品制作方法和食物搭配建议的手机软件,其核心功能在于为用户提供便
2023-06-05
自己做的app上架赚钱
近年来,随着智能手机和平板电脑的普及,越来越多的人开始利用自己的技术和创意开发手机应用软件(App)。那么自己做的App上架赚钱的原理是什么呢?本文将介绍相关的知识点。1.应用商店介绍常见的应用商店包括苹果 App Store、Google Play、华为
2023-06-05
自己做水印的app
在现在这个时代,随着现代科技和互联网的快速发展,大多数人都有了自己的手机和相机,喜欢记录下生活中的点滴,并通过社交媒体与亲朋好友分享。但是,这种分享也面临着一些问题,比如说可能会被恶意转发和盗用,这无疑是一种影响个人隐私和权益的行为。为了保护我们自己的照片
2023-06-05
自己做一款商城app需要什么工具
要开发一个商城app,需要具备以下几点:1.编程知识和技能首先,你需要具备基本的编程知识和技能。Android的开发语言为Java和Kotlin,而iOS的开发语言为Swift和Objective-C。学习这些语言并熟练掌握它们,有助于你更好地理解和开发商
2023-06-05
自己开发app控制家电
随着智能家居市场的逐步普及,越来越多的人开始关注如何通过手机app来控制家电,方便自己的生活。以下是自己开发app控制家电的原理和详细介绍。一、原理自己开发app控制家电的原理相对简单,主要涉及到以下几个步骤。1.收集数据:首先需要收集家电的相关数据,包括
2023-06-05
自己制作一个考试的app
制作一个考试的app,需要掌握一定的编程知识和技能。具体的步骤如下:1. 确定需求在制作一个考试的app之前,需要明确考试的类型、题目数量、难度等方面的需求。例如,是单选题还是多选题,是计算题还是填空题等等。2. 准备题目库根据需求,准备相应的题目库。题目
2023-06-05
自己做app创业难吗知乎
创业本身就是难的,不管是做APP还是其他领域的创业。但是对于做APP创业而言,也有其特殊性和难点。首先,对于创业者来说,做APP所面临的竞争是非常激烈的。毕竟APP Store和Google Play上有数以百万计的应用程序,要让自己创业的APP能够脱颖而
2023-06-05
怎么自己开发app软件不用上架
在开发APP软件时,我们通常需要将应用程序上传到应用商店上架,然后用户才能下载使用,但是有些情况下我们需要在不上架的情况下使用APP软件,如内部企业应用、特殊场景的应用等,这时候就需要使用“企业签名”方式进行分发。企业签名(Enterprise signi
2023-06-05
上海自营商城app开发
上海自营商城是一款电商平台,用户可以在上海自营商城app上购买来自上海地区的商品。该应用程序基于Android和iOS操作系统开发,由上海市公共资源交易中心运营。上海自营商城app的开发分为以下几个部分:1.需求分析:在开发应用程序之前,需要进行需求分析,
2023-05-30
黑马培训完能自己开发app吗
黑马培训是一家专业的IT职业教育机构,提供了广泛的课程以帮助学生进一步提升自己的技能和知识。如果你参加了黑马培训,学会如何开发自己的 APP 是完全有可能的。首先,黑马培训的课程教授了流行的移动应用平台,包括 iOS、Android 和 React Nat
2023-05-30
包括自行开发app
开发一款app可以说是现代商业中非常重要的一环,因为它可以让企业与客户之间的接触更加频繁和紧密,用户也可以通过app更加轻松的获取到企业信息和服务,并能享受到更好的用户体验。那么,如何自行开发app呢?第一步,确定项目需求和目标。在决定开发一款app之前,
2023-05-30
©2015-2021 自建app开发平台 www.appbyme.cn 蜀ICP备17005078号-1