当前位置: 首页 > news >正文

用python自动标注word试题选项注意事项

1. 先把word内容全选,再右键以文本形式保存,防止有的题ABCD是文本,有的题ABCD选项是word编号;

2. 如果ABCD选项有大量缺项,以A为一个循环切换答案输入:

在此之前,用查找补充齐A,保证每题都有A选项。查找时,可以100个为一组,再用2分法加速找到缺A项的题:

程序模板:

from docx import Document
from docx.shared import RGBColor# 读取 Word 文件
word_file_path = 'D:/实验室/小任务/标答案/仅保留文本.docx'  # 替换为你的 Word 文件路径
doc = Document(word_file_path)# 给定的列表(例如:['a', 'b', 'd'])
highlight_str = ["ABCCBCCBABABBABABDABBBCBBBDCADADBCDBAADDDADCAABBBADBABBDACCBAAAACDCAADBCBCCBDBBDDCBACCBBBBBBBBBBBBBBCBCDBDBCBDDAADBBCCCCDCBABBABBCAABCAA"]
highlight_list = list(highlight_str[0])  # 将字符串转为字符列表# 用于追踪“abcd”循环的计数器
abcd_count = 0
# 用于追踪 highlight_list 中当前的字母索引
highlight_index = -1# 定义一个函数用于在字符后添加文本
def add_text(paragraph, highlight_list):global abcd_countglobal highlight_index# 遍历段落的所有 runsruns = paragraph.runsfor run in runs:# 遍历当前 run 中的每个字符for i, char in enumerate(run.text):if char in 'ABCD':  # 只处理字母 A, B, C, Dif char == 'A':abcd_count = 0highlight_index = highlight_index + 1# 如果当前字符是需要标记的字母if char == highlight_list[highlight_index]:# 在字符后追加 "[正确答案]",并设置为红色run.text = run.text[:i + 1] + '【正确答案】'  # 在字符后追加文本# run.font.color.rgb = RGBColor(255, 0, 0)  # 设置文本为红色# 打印调试信息print(f"Added '[正确答案]' after char: {char} at index {highlight_index}")# 每次遇到一个字母,我们更新计数器和列表索引abcd_count += 1# 遍历文档中的段落并处理
for para in doc.paragraphs:add_text(para, highlight_list)# 保存更新后的 Word 文件
highlighted_file_path = 'D:/实验室/小任务/标答案/标记测试.docx'
doc.save(highlighted_file_path)print(f"文档已保存,路径为:{highlighted_file_path}")

答案放这就好:

感悟:

word自动化处理编程本身不难,难在word格式不规则的话,就得找到规则的部分加以利用,必要时得对word进行些预处理。

不然的话,就得提升程序的鲁棒性,能识别处理同一个东西的不同形式,如大小写、字体样式等等。

http://www.xdnf.cn/news/1179361.html

相关文章:

  • 安全逆向工程学习路线
  • 4.1.2 XmlInclude 在 C# 中的作用及示例
  • 【Unity开发】数据存储——XML
  • web:js函数的prototype(原型对象)属性
  • Opentrons 模块化平台与AI技术助力智能移液创新,赋能AAW™自动化工作站
  • 电商项目_秒杀_架构升级
  • YOLOv4深度解析:革命性的实时目标检测技术
  • 报告研读——103页数据资产价值实现研究报告( 2023)【附全文阅读】
  • 【ECharts✨】解决Vue 中 v-show 导致组件 ECharts 样式异常问题
  • PAT 甲级题目讲解:1003《Emergency》
  • Apache Commons:Java开发者的瑞士军刀
  • C语言第四章函数
  • Perf编译和使用
  • kettle插件-kettle数据挖掘ARFF插件
  • 2025年7月23日 AI 今日头条
  • 【已解决】YOLO11模型转wts时报错:PytorchStreamReader failed reading zip archive
  • C++实现精确延时的方法
  • 鸿蒙平台运行Lua脚本
  • 论文阅读:《无约束多目标优化的遗传算法,群体和进化计算》
  • 【Word Press进阶】自定义区块的行为与样式
  • Linux(centos7)安装 docker + ollama+ deepseek-r1:7b + Open WebUI(内含一键安装脚本)
  • Terraform与Ansible的关系
  • MCNN-BiLSTM-Attention分类预测模型等!
  • 行为型模式-协作与交互机制
  • fabric搭建基础的测试网络
  • 时序数据库IoTDB的核心功能特性
  • 重构数据库未来:金仓数据库,抢占 AI 原生时代先机
  • Java 大视界 -- Java 大数据在智能教育自适应学习路径规划与学习效果强化中的应用(362)
  • [数据结构]#7 哈希表
  • 造成服务器内存不足的原因有什么