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模塊的一個讀寫練習

以上就是本文的全部內容,希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。

推薦閱讀: