python实现某考试系统生成word试卷

 更新时间:2021年05月17日 11:32:47   作者:々橙若℃ №  
这篇文章主要为大家详细介绍了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模块的一个读写练习

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 使用Matplotlib 绘制精美的数学图形例子

    使用Matplotlib 绘制精美的数学图形例子

    今天小编就为大家分享一篇使用Matplotlib 绘制精美的数学图形例子,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-12-12
  • cv2.imread 和 cv2.imdecode 用法及区别

    cv2.imread 和 cv2.imdecode 用法及区别

    对于路径中含有中文的图像,直接用cv2.imread读取会报错,上次看到有大佬使用cv2.imdecode就可以正常读取,有点好奇,所以今天来记录下二者用法和区别,感兴趣的朋友跟随小编一起看看吧
    2023-02-02
  • Python实现提取指定名称的文件并批量复制到其他文件夹

    Python实现提取指定名称的文件并批量复制到其他文件夹

    本文介绍基于Python语言,读取一个文件夹,并将其中每一个子文件夹内符合名称要求的文件加以筛选,并将筛选得到的文件复制到另一个目标文件夹中的方法,需要的朋友可以参考下
    2023-10-10
  • 总结归纳python os库常用方法

    总结归纳python os库常用方法

    这篇文章主要为大家介绍了python os库常用方法的总结归纳,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • Python线性表种的单链表详解

    Python线性表种的单链表详解

    这篇文章主要介绍了Python线性表种的单链表详解,线性表是一种线性结构,它是由零个或多个数据元素构成的有限序列。线性表的特征是在一个序列中,除了头尾元素,每个元素都有且只有一个直接前驱,有且只有一个直接后继
    2022-08-08
  • 哪些是python中web开发框架

    哪些是python中web开发框架

    在本篇文章里小编给大家整理的是关于python的web开发框架的总结内容,有兴趣的朋友们学习下吧。
    2020-06-06
  • Python 文件读写操作实例详解

    Python 文件读写操作实例详解

    Python提供了必要的函数和方法进行默认情况下的文件基本操作。你可以用file对象做大部分的文件操作
    2014-03-03
  • Python集成学习之Blending算法详解

    Python集成学习之Blending算法详解

    集成学习(又称模型融合)就是结合若干个体分类器(基学习器)进行综合预测,各个个体学习器通常是弱学习器.集成学习相较于个体学习在预测准确率以及稳定性上都有很大的提高.文中有非常详细的代码示例哦,需要的朋友可以参考下
    2021-05-05
  • windows下python虚拟环境virtualenv安装和使用详解

    windows下python虚拟环境virtualenv安装和使用详解

    这篇文章主要介绍了windows下python虚拟环境virtualenv安装和使用详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-07-07
  • python读取excel数据并且画图的实现示例

    python读取excel数据并且画图的实现示例

    这篇文章主要介绍了python读取excel数据并且画图的实现示例,帮助大家更好的理解和使用python,感兴趣的朋友可以了解下
    2021-02-02

最新评论