Python办公自动化实现考试系统生成Word试卷【2】

2024-08-21 19:04

本文主要是介绍Python办公自动化实现考试系统生成Word试卷【2】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

每次做等级测试试题和答案顺序总是不一样!!! 原来是这样啊!!   

搞清楚这些和小伙伴聊天又有话题了。

生活中你有留意各种测试等级的考试试卷吗? 你应该会看到每次测试题目和答案好像都差不多,只是每次题目出现的顺序和答案的顺序是被打乱的。

这里我们就用python自动化实现考试系统生成Word试卷,每次生成的试卷试题和答案都是随机生成被打乱的。

目录

一、xlrd模块读取数据

二、生成试题和答案选项数据

三、用python-docx模块生成word试卷

四、运行结果


一、xlrd模块读取数据

1.新建项目并导入试题数据文件

这里准备了试题库命名为testdata并导入项目中。

试题excl数据列表图

项目新建testproject.py文件

项目新建py文件

导入第三方插件并读取excel数据以及工作表。主要是读取excel插件、随机打乱数据插件以及生成word文件需要用到的插件。如何下载安装使用前面一章有详细说明。

# 导入需要的第三方插件
import xlrd  #读取excel文件
import random #随机打乱数据#生成 word文件需要用到的
from docx import Document
from docx.shared import Pt,RGBColor
from docx.enum.text import WD_ALIGN_PARAGRAPH#1.获取excel文件数据
data = xlrd.open_workbook('testdata.xls')
sheet = data.sheet_by_index(0) #获取工作表

二、生成试题和答案选项数据

现在我们已经拿到excel导入的试图数据,下一步需要对试题数据进行打乱操作,并把试题答案序号进行打乱。目的是使每一次生成的数据顺序是不一样的。

定义一个createQuestion的方法,最终return 一个经过打乱之后的数据questionlist列表。具体实现过程如下代码所示:

# 定义一个试题的类
class Question:pass
# 生成试题的方法
def createQuestion():# 定义列表用来存储处理后的试题数据questionlist = []for i in range(sheet.nrows):if i>1:obj = Question() #实例化对象并把试题中的值添加到对象中obj.subject = sheet.cell(i,1).value #题目obj.questiontype = sheet.cell(i,2).value #题型obj.option = []obj.option.append(sheet.cell(i,3).value) #aobj.option.append(sheet.cell(i,4).value) #bobj.option.append(sheet.cell(i,5).value) #cobj.option.append(sheet.cell(i,6).value) #dobj.score = sheet.cell(i,7).value #分值# 把对象数据添加到列表中questionlist.append(obj)#将序列所有的元素随机排序        random.shuffle(questionlist) # 把最终经过打乱后的数据返回return questionlist

三、用python-docx模块生成word试卷

拿到经过打乱后的试图数据,下一步需要生成word试卷。生成word主要分为三步:1.生成页眉页脚 、2.试卷信息、3.试题信息

# 生成word试卷
def createPaper(filename,papername,questionlist):document = Document()# 页眉页脚section = document.sections[0]header = section.headerp1 = header.paragraphs[0]p1.text = papernamefooter = section.footerp2 = footer.paragraphs[0]p2.text = '内部试题,禁止泄露'# document.sections[0].footer.paragraphs[0].text = # 试卷信息title = document.add_heading(papername,level=1)title.alignment=WD_ALIGN_PARAGRAPH.CENTERp3 = document.add_paragraph()p3.add_run('姓名:______')p3.add_run('所属部门:______')p3.alignment = WD_ALIGN_PARAGRAPH.CENTER# 试题信息for questionitem in questionlist:subject = document.add_paragraph(style='List Number') #style设置题目前面的序号run = subject.add_run(questionitem.subject) run.bold = True # 题目设置加粗显示subject.add_run('【%s】分'% str(questionitem.score))random.shuffle(questionitem.option) #打乱选项的序号for index,option in enumerate(questionitem.option):document.add_paragraph(('ABCD')[index]+str(option))document.save(filename)  

四、运行结果

现在我们生成试题方法和生成试卷方法都已经完成了,下一步,加入我们要生成10份试卷供10位考生来使用。那么循环执行10次即可:

for i in range(10):questionlist = createQuestion()createPaper('testpaper'+str(i+1)+'.docx','2024第一季度内部测试',questionlist)       

经过执行文件后我们可以看到同级文件夹生成了10份word文件试卷。 我们打开看下生成的试题和答案是否被打乱呢?

文件夹中生成10份word试题图片

不同试卷第一题出现的题目不一样对比图

 相同题目答案顺序不一样对比图

我们打开其中的两份第一份和第六份试题,可以看到第一题的试题是不一样的,而且同一道测试题答案顺序也是不一样的。 

python环境搭建入门基础知识  |  python网络爬虫爬数据  |  python办公自动化处理Excel数据

这篇关于Python办公自动化实现考试系统生成Word试卷【2】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1094018

相关文章

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2

Python Jupyter Notebook导包报错问题及解决

《PythonJupyterNotebook导包报错问题及解决》在conda环境中安装包后,JupyterNotebook导入时出现ImportError,可能是由于包版本不对应或版本太高,解决方... 目录问题解决方法重新安装Jupyter NoteBook 更改Kernel总结问题在conda上安装了

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

Python安装时常见报错以及解决方案

《Python安装时常见报错以及解决方案》:本文主要介绍在安装Python、配置环境变量、使用pip以及运行Python脚本时常见的错误及其解决方案,文中介绍的非常详细,需要的朋友可以参考下... 目录一、安装 python 时常见报错及解决方案(一)安装包下载失败(二)权限不足二、配置环境变量时常见报错及

Python中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操