python实现某考试系统生成word试卷
作者:々橙若℃ № 发布时间:2022-05-20 18:29:09
标签:python,考试系统,word
本文实例为大家分享了python实现某考试系统生成word试卷的具体代码,供大家参考,具体内容如下
提示:写完文章后,目录可以自动生成,如何生成可参考右边的帮助文档
准备条件
1.试题excel信息,存放在名为data.xls的excel文件中
2.安装python依赖的模块信息
pip install xlrd
pip install python-docx
提示:以下是本篇文章正文内容,下面案例可供参考
编码实现
#!/bin/bash env python
import xlrd
import random
from docx import Document
from docx.shared import Pt, RGBColor
from docx.enum.text import WD_ALIGN_PARAGRAPH
#打开excel
data = xlrd.open_workbook('data.xls')
#获取工作表
sheet = data.sheet_by_index(0)
class Question:
pass
def create_question():
question_list = []
for i in range(sheet.nrows):
if i>2:
#创建试题类
question = Question()
question.ID = sheet.cell(i,0).value
#添加试题的题目信息
question.subject = sheet.cell(i,1).value
#添加题目类型
question.question_type = sheet.cell(i,2).value
#添加试题选项
question.option = []
question.option.append(sheet.cell(i, 3).value) # A
question.option.append(sheet.cell(i, 4).value) # B
question.option.append(sheet.cell(i, 5).value) # C
question.option.append(sheet.cell(i, 6).value) # D
#添加分值
question.score = sheet.cell(i,7).value
question_list.append(question)
#将试卷题目随机打乱并且返回
random.shuffle(question_list)
return question_list
def create_papper(file_name,paper_name,question_list):
#创建一个文档对象
document = Document()
#设置页眉的位置信息
section = document.sections[0]
header = section.header
p1 = header.paragraphs[0]
p1.text = paper_name
#设置页脚信息
footer = section.footer
p2 = footer.paragraphs[0]
p2.text = '内部试题,禁止泄露'
#写入试卷基本信息
titile = document.add_heading(paper_name,level=1)
#设置对齐方式
titile.alignment = WD_ALIGN_PARAGRAPH.CENTER
#添加一个段落
p3 = document.add_paragraph()
p3.add_run('姓名:____')
p3.add_run('班级:____')
p3.alignment = WD_ALIGN_PARAGRAPH.CENTER
#写入试题信息
for i,question in enumerate(question_list):
subject_paragraph = document.add_paragraph() #添加一个段落
run = subject_paragraph.add_run(str(i+1)+str(question.subject)) #添加题目信息
run.bold = True #设置加粗
subject_paragraph.add_run('【%s】分'%str(question.score))
#打乱选项的顺序
random.shuffle(question.option)
for index,option in enumerate(question.option):
document.add_paragraph(('ABCD')[index]+str(option))
#保存试题
document.save(file_name)
return
if __name__ == '__main__':
question_list = create_question()
#循环生成100份试卷
for item in range(1,100):
create_papper('2021第'+str(item)+'套内部考试试题.docx','2021第一季度内部考试',question_list)
print('over')
实现效果
总结
该案例综合使用了xlrd模块和python-docx模块的一个读写练习
来源:https://blog.csdn.net/u014265398/article/details/115709315
0
投稿
猜你喜欢
- 本文详细讲述了Python使用MySQLdb for Python操作数据库的方法,分享给大家供大家参考。具体如下:一般来说网站就是要和数据
- 本文实例总结了PHP常用字符串操作函数。分享给大家供大家参考,具体如下:/*常用的字符串输出函数** echo() 输出字符串* print
- 可以查看mysql文件目录my.ini文件,可以找到类似于 datadir="D:/beeagle/Program Files/M
- 简单介绍:Selenium是一个Web的自动化测试工具,最初是为网站自动化测试而开发的,Selenium 可以直接运行在浏览器上,它支持所有
- 代码如下Control:from django.conf.urls import patterns, include, urlfrom dj
- 在本文中,我们将探讨一种简洁的方式,以此来可视化你的MP3音乐收藏。此方法最终的结果将是一个映射你所有歌曲的正六边形网格地图,其中相似的音轨
- 1. 引言在数据处理、机器学习等领域,我们经常需要对各式各样的数据进行处理,本文重点介绍三种非常简单的方法来检测数据集中的异常值。 
- PyQt5滚动条控件QScrollBar简介可以看到,前面介绍的几个窗口控件的共同点是新建一些窗口来装载更多的控件,而QScrollBar提
- numpy库概述numpy库处理的最基础数据类型是由同种元素构成的多维数组,简称为“数组”数组的特点:数组中所有元素的类型必须相同数组中元素
- python库-密码学库pynacl什么是pynacl官方: https://pynacl.readthedocs.io/en/latest
- 协程协程(co-routine,又称微线程)是一种多方协同的工作方式。当前执行者在某个时刻主动让出(yield)控制流,并记住自身当前的状态
- 滑动拼图验证码可以算是滑块验证码的进阶版本,其验证机制相对复杂。本节将介绍两种滑动拼图验证码:初级版和高级版本。初级版滑块拼图验证码初级版滑
- 1、 设置WriteHeader的顺序问题之前遇到个问题,在一段代码中这样设置WriteHeader,最后在header中取Name时怎么也
- 引言在 Python 中,输入和输出格式化是一项重要的技能,它可以帮助你更好地与用户进行交互,以及更有效地展示数据。本节将介绍如何使用字符串
- 前言为了介绍python语言中pandas库在数据分析中的重要作用,本人打算以NBA球星勒布朗詹姆斯在2020-2021赛季常规赛个人数据为
- 淡入淡出图片轮换轮播效果,可以做新闻图片推荐需要的拿去用,效果预览请点击运行代码相关效果推荐:迅雷首页新闻图片轮播效果js源码 <!D
- 一、检测通信查看master(centos7)和slave(win10)的ip地址,并检测是否可以相互通信到这里我们知道,master的ip
- 今天在开发一个手机短信通讯录的前端界面时,界面中使用了checkbox,来做为各项的选择控件,但是操作时,除了点差子。由于逻辑需要,需要预先
- 方法1:SET GLOBAL general_log = 'OFF';RENAME TABLE mysql.general_
- 前言:随着编程语言的发展,Go 还很年轻。它于 2009 年 11 月 10 日首次发布。其创建者Robert Griesemer Rob