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。
推薦閱讀:
- 一文教你如何用Python輕輕松松操作Excel,Word,CSV
- Python操作word文檔的示例詳解
- Python辦公自動化從Excel中計算整理數據並寫入Word
- Python+MySQL隨機試卷及答案生成程序的示例代碼
- Python從MySQL數據庫中面抽取試題,生成試卷