吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 5027|回复: 114
收起左侧

[原创工具] Word简单题库转Excel&关键字快速查询Excel题库

    [复制链接]
mingzial 发表于 2024-7-27 15:49
本帖最后由 mingzial 于 2024-7-28 15:18 编辑

一、Word题库转Excel

1、Word题库格式要求

内容 格式要求 事例
题目 数字+中文顿号 1、我是题目
选项 英文字母+英文点 A.我是选项
答案 中文汉字+英文冒号 答案:我是答案

2、Word题库支持题型

支持题型 答案要求
单项选择题 单个英文字母
多项选择题 多个不重复英文字母
判断题 '√', '×', '对', '错'
填空题、问答题等 单一非空字符串(如多个填空,需把答案组合为一条记录)

3、Word题库内容展示

enter description here

4、Python转换代码

# -*- coding: cp936 -*-

import docx
import openpyxl
import re

def check_answer_type(answer_index):
    if answer_index.encode().isalpha() and len(answer_index) == 1:#单选
        answers.append(options_dict.get(answer_index, "Unknown"))
        questions_type.append("单选题")
    elif answer_index.encode().isalpha():#多选
        answers.append('\r\n'.join([options_dict.get(char, "Unknown") for char in answer_index]))
        questions_type.append("多选题")
    elif answer_index in ['√', '×', '对', '错']:#判断
        questions_type.append("判断题")
        answers.append(answer_index)
    else:#其他,填空/问答等
        questions_type.append("其他题")
        answers.append(answer_index)

doc_path = input("输入Word文件路径:")
wb_path = input("输入Excel文件路径:")

questions = []
questions_type = []
options_dict = {}
options_count = []
answers = []
answers_count = []

try:
    # 读取Word文档
    doc = docx.Document(doc_path)

    for para in doc.paragraphs:
        if para.text.strip() == "":#空行
            continue
        elif re.match(r'^\d+、', para.text):#题目,数字+、
            print(f"正在读取:{para.text}")
            questions.append(para.text.strip())
        elif re.match(r'^[A-Z]\.', para.text):#选项,字母+.
            options_dict[para.text.split(".")[0].strip()] = para.text.split(".")[1].strip()
        elif re.match(r'^答案:', para.text):#答案,答案+:
            answer_index = para.text.split(":")[1].strip()
            check_answer_type(answer_index)
            options_count.append(len(options_dict))
            answers_count.append(len(answer_index))
            options_dict.clear()
        else:
            raise ValueError(f"格式错误:{para.text}")

    # 创建一个Excel工作簿
    wb = openpyxl.Workbook()
    ws = wb.active
    ws.title = "题目及答案"
    ws['A1'] = '题目'
    ws['B1'] = '答案'
    ws['C1'] = '题目类型'
    ws['D1'] = '选择项个数'
    ws['E1'] = '答案个数或长度'

    # 将题目和答案写入Excel文件
    for i in range(len(questions)):
        ws[f'A{i+2}'] = questions[i]
        ws[f'B{i+2}'] = answers[i]
        ws[f'C{i+2}'] = questions_type[i]
        ws[f'D{i+2}'] = options_count[i]
        ws[f'E{i+2}'] = answers_count[i]

    # 保存Excel文件
    wb.save(wb_path)
    print("转换完成:题目和答案已成功写入Excel文件。")

except Exception as e:
    print(f"发生错误:{e}")

input("按任意键退出...")

5、运行报错及解决方法

  软件如若报错,打开Word题库,定位到出错的位置,检查修改至满足上诉格式要求。
enter description here

6、已知问题

  因Word题库格式存在的不确定性,难免有不可预见问题。如若软件提示转换完成,请检查核对生成Excel题库文件的正确性。

二、关键字快速查询题库

1、Excel题库格式说明

  Excel题库可用上述软件转换,也可自行制作(自行制作,仅需制作A列、B列即可)。

列数 内容 软件读取列
A列 题目 读取
B列 正确答案 读取
C列 题目类型 不读取
D列 选择项个数 不读取
E列 答案个数或长度 不读取

2、转换Excel题库检查说明

  使用转换方式获取Excel题库,请自行检查核对生成Excel题库文件的正确性,包括并不限于仅检查以下内容。

题型 检查内容
单选题 筛选检查选项个数是否存在遗漏,答案个数是否为1
多选题 筛选检查选项个数是否存在遗漏
判断题 筛选检查选项个数是否为0,答案个数是否为1,答案格式是否正确
其他题 筛选检查选项个数是否为0,答案长度是否大于0
检查有效行数与Word题库数量是否一致
检查题目、答案是否有误

3、Excel题库内容展示

enter description here

4、软件使用

  ①启动软件,并打开题库
enter description here
  ②查询方式

查询方式 说明
输入关键字,点击按钮查询 前台查询
输入关键字,按键“ALT+S”查询 前台查询
复制关键字,按键“CTRL+X”查询 全局查询

  ③查询结果仅为1题时,效果展示
在这里插入图片描述
  ④查询结果为多题时,效果展示(在软件左侧上部分点击选择或输入更多关键字查询)
在这里插入图片描述
  ⑤查询结果为空时,效果展示
在这里插入图片描述
  ⑥查询题目重复,效果展示
在这里插入图片描述

三、软件说明及下载链接

  1、“Word题库转Excel”开发环境:Python 3.9;
  2、“查询Excell”开发环境:.NET8;
  3、软件支持题目重复;
  4、若考核网页(软件)不支持题目复制,尝试使用浏览器插件解除复制或使用ocr软件辅助;
  5、下载链接:蓝奏云,密码:59f4。

四、土豪通道

  内容为上文蓝奏云链接,感谢支持。: 下载链接.txt (50 Bytes, 下载次数: 19)

免费评分

参与人数 20吾爱币 +28 热心值 +17 收起 理由
yilesoft + 1 + 1 谢谢@Thanks!我先保存肯定会用到。
Zatoichi + 1 + 1 谢谢@Thanks!
lccccccc + 2 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!
bqi153 + 1 + 1 谢谢@Thanks!
xiaohang621 + 1 谢谢@Thanks!
maxinxi + 1 + 1 我很赞同!
abclihongzhi + 1 谢谢@Thanks!
schtg + 1 + 1 谢谢@Thanks!
pluso + 1 + 1 鼓励转贴优秀软件安全工具和文档!
1045837055lucy + 2 + 1 谢谢@Thanks!
huachenbin + 1 + 1 热心回复!
CHIEFLY123 + 1 + 1 我很赞同!
vethenc + 2 + 1 谢谢@Thanks!
风之暇想 + 7 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!
qqqaqqq + 1 非常实用,谢谢@Thanks!
helh0275 + 1 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!
yanglinman + 2 谢谢@Thanks!
washaoyang + 1 + 1 我很赞同!
vip1639253946 + 1 谢谢@Thanks!
pcx127 + 1 + 1 谢谢@Thanks!

查看全部评分

本帖被以下淘专辑推荐:

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

 楼主| mingzial 发表于 2024-7-28 10:23
KZLY2024 发表于 2024-7-28 07:25
再加入多选和填空判断就可以做一个在线测试了

因为题库的不确定性,Python代码没有去处理转换那些题型,可自行处理。
查询软件其实可以支持这些题型,不管是单选、多选、判断、填空、问答等,只需要A列是题目B列是答案就可以正常使用。
ilvwapj0 发表于 2024-8-4 15:10
gvbcn 发表于 2024-8-4 10:06
能不能提供一个word样本,根据样本格式修改,题目有500个,是不是太多导致的,没权限,无法上传截图

按楼主贴子里图片形式样本一般不会出错。
另注意楼主代码不支持题干或选项为多段内容。
chaes 发表于 2024-7-27 16:00
wstsc 发表于 2024-7-27 16:07
Thanks for sharing
tutu2 发表于 2024-7-27 16:11
牛啊兄弟   太强了
头像被屏蔽
qiange666 发表于 2024-7-27 16:11
提示: 作者被禁止或删除 内容自动屏蔽
52soft 发表于 2024-7-27 16:14
值得学习
wangziqiu1122 发表于 2024-7-27 16:26
感谢分享!
vip1639253946 发表于 2024-7-27 16:31
感谢楼主分享
pudding20112002 发表于 2024-7-27 16:43
感谢分享
zlf2020999 发表于 2024-7-27 16:54
这个是干嘛?出题用的吗?谢谢分享!@
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-22 00:48

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表