如何用Python批量计算Word中的算式

一、问题的提出

到了期末,大家都在忙着写总结、改试卷、算工作量,写总结可以借助于ChatGPT,改试卷可以用星火的自动批阅功能,算工作量就是一项比较棘手的问题,因为它涉及很多算式,有时需要老师用计算器算来算去,因为里面有括号的问题,所以手工算起来非常麻烦。历经十多年的算工作量,我摸索出了一套方法今天与大家分享一下,也算是为大家减轻一下负担,提升工作效率,把工作量算的又快又准。

工作量样例

以上是一张工作量的样图,我们的目标是,把教学工作计算式一列算出来,并填写在标准学时一栏里面。

二、问题的解决

1.搜索引擎法

这种方法很简单,就是把教学工作算式那里的内容复制一下,放到bing搜索框里面,然后回车就可以自动计算出算式的数值,如下图所示。不过,你还需要把这个数值进行四舍五入填写到标准学时那里。这样,有几项任务就要搜索几次,虽然次数比较多,但是上手比较容易,而且不用修改任何算式的内容。

搜索引擎计算

Bing搜索对算式中的符号没有过于严格的要求,如果你想使用百度来计算就要把里面的乘号改为【*】号,中括号改为小括号【()】,这样就可以搜出算式的答案了。如下图所示:

用百度来计算算式

需要注意的是,算式中的符号需要在英文的半角状态下进行,否则就可能报错。

2.Excel表法

多年了,我们已经习惯用Word来计算工作量,原因很简单,就是Word制作表格似乎更方便,也容易调整格式,说白了没有什么技术含量,但是在Word中应用公式,打序号相对比较麻烦,如果模式是Excel表的话,那计算就相对简单一点儿了,为此,我特地把Word表格转化成了Excel表格。为了保证Word表格的格式不改变,我们可以用以下方法,先把Word文件存为htm格式的网页文件,再用Excel打开这个文件,格式就不会变了。可以参考以下方法源自网络[1]。

使用另存为功能:
1. 在Word中打开文档,点击“文件”菜单,选择“另存为”。
2. 在弹出的“另存为”窗口中,选择保存类型为“网页(*.htm; *.html)”,然后点击“保存”。
3. 打开Excel,点击“文件”菜单,选择“打开”。
4. 在“打开”窗口中,找到保存的HTML文件并打开。此时,文档的排版将完整地被导入到Excel中。

Word表格转化为Excel表

采用这种方法,可以充分发挥Excel的计算功能,在标准学时下面的单元格中应用函数:

=round(evaluate(J5),2)

就可以直接把算式计算出来,并且保留小数点后面二位数字,然后向下拖动鼠标,计算所有算式,最后用【Alt+=】求和。但是缺点也很明显,就是要进行格式转化,另外算式中的乘号也要换成星号,方括号也要变成小括号,如果Excel操作不熟练的话,建议还是使用第一种方法来解决。

3.Python代码实现

第一种方法一次只能算一个算式,第二种方法可以算好一个算式后,向下拖动实现全部算式的计算,那用Python可以一次性算完所有的算式,并且自动求和【功能后续添加】。即使算式中有乘号、中括号也可以通过编程的方法进行批量替换。以下代码由我个人与ChatGPT共同完成,实现过程包括,读取docx文件,获取指定列内容,筛选出包含数字的算式,格式化算式后对算式进行计算,并保留小数点2位。

from docx import Documentdef has_digits(s):return any(char.isdigit() for char in s)def replace_operators(expression):# 定义映射符号intab = "×[]"outtab = "*()"# 生成映射表transtab = str.maketrans(intab, outtab)# 批量的字符替换,对算式进行格式化expression = expression.translate(transtab)return expressiondef process_table(table):# 循环每一行for row in table.rows:# 获取J列的值(假设J列对应的是索引11)j_cell = row.cells[11].text# 替换不规则的乘号和中括号j_cell = replace_operators(j_cell)# 只取有数字的单元格的内容if has_digits(j_cell):try:# 计算结果并保留2位小数result = round(eval(j_cell), 2)# 将结果写入K列(假设K列对应的是索引12)row.cells[12].text = str(result)except Exception as e:print(f"Error processing expression in row {e}")def process_word_document(file_path):document = Document(file_path)for table in document.tables:process_table(table)# 保存文档document.save(file_path)# 用法示例
word_file_path = '如何用word统计工作量.docx'
process_word_document(word_file_path)

Python代码的优点是运算快,可以同时处理多个文件,不用担心算式不统一,小数点没有保留2位等问题。

三、学后反思

  1. 上面是生活中应用搜索引擎、Excel和Python的一个小案例,可以看出,对于算式的计算方法多样,大家可以选择适合自己的方法,如果算式不多,搜索引擎法简单实用,如果想一劳永逸就转换为Excel表来计算工作量,简单实用。如果是想批量处理文件就用Python,几十个人的工作量估计10秒左右就算完了。
  2. 上面的代码经测试可用,但是还有一项汇总的内容,后续我还要加上去,这样计算算式、保留2位小数、汇总数据,一气呵成,鼠标一点就完成了批量任务。

参考

  1. ^如何把Word表格转化为Excel不变格式 百度安全验证icon-default.png?t=N7T8https://baijiahao.baidu.com/s?id=1779913471459003540&wfr=spider&for=pc

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/227828.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

springcloud微服务篇--6.网关Gateway

一、为什么需要网关? 网关功能: 身份认证和权限校验 服务路由、负载均衡 请求限流 在SpringCloud中网关的实现包括两种: gateway zuul Zuul是基于Servlet的实现,属于阻塞式编程。而SpringCloudGateway则是基于Spring5中提供的Web…

蓝牙物联网移动硬件数据传输系统解决方案

随着传感器技术、网络技术和数据传输技术的不断发展,人们对智能设备的需求日渐增强,利用传感器技术可以对周围环境进行准确和全面的感知,获取到实时信息,从而在网络中进行传输和共享,再通过服务器对各种数据进行保存、分析和挖掘等…

Redis6.0 Client-Side缓存是什么

前言 Redis在其6.0版本中加入了Client-side caching的支持,开启该功能后,Redis可以将指定的key-value缓存在客户端侧,这样当客户端发起请求时,如果客户端侧存在缓存,则无需请求Redis Server端。 Why Client-side Cac…

Oracle OCP怎么样线上考试呢

大家好!今天咱们就来聊聊Oracle OCP这个让人又爱又恨的认证。为啥说又爱又恨呢?因为它既是IT界的“金字招牌”,又是一块硬骨头,不是那么容易啃下来的。好了,废话不多说,我们直奔主题,来看看关于…

Docker (compose、安装、常用命令整理、compose编排) -day06

一、概念 Docker-Compose就是容器编排,负责实现对Docker容器集群的快速编排 Compose允许用户通过一个单独的docker-compose.yml模板文件(YAML 格式)来定义一组相关联的应用容器为一个项目(project)。 可以很容易地用一…

第二部分 离散型随机变量

目录 求分布律里的未知数 例1 例2 根据X的分布律写Y的分布律 例3 根据(X,Y)的分布律写Z的分布律 例4 根据(X,Y)的分布律写边缘分布律 例5 X与Y相互独立时的联合分布律 例6 根据分布律求期望、方差 例7 求分布律里的未知数 例1 已知X的分布律为 X-202P0.40.3k ,试求k 解 0.40…

javaEE -18(11000字 JavaScript入门 - 3)

一:事件 (高级) 1.1 注册事件(绑定事件) 给元素添加事件,称为注册事件或者绑定事件,注册事件有两种方式:传统方式和方法监听注册方式 传统注册方式 : 利用 on 开头的…

Rust开发⼲货集(1)--迭代器与消费器

本内容是对 Rust开发干货集[1] 的实践与扩展. iter() 不转移所有权 先简单解释下什么叫"转移所有权": 在 Rust 中,"转移所有权"(Ownership Transfer)是一种核心概念,它涉及变量和数据的所有权从一个实体转移…

CentOS7安装部署Zookeeper

文章目录 CentOS7安装部署Zookeeper一、前言1.简介2.架构3.集群角色4.特点5.环境 二、正文1.部署服务器2.基础环境1)主机名2)Hosts文件3)关闭防火墙4)JDK 安装部署 3.单机部署1)下载和解压2)配置文件3&…

【docker】—— Docker 简介

目录 (一)容器技术发展史 1、Jail 时代 2、云时代 3、云原生时代 (二)编排与容器的技术演进之路 1、DockerClient 2、RUNC&Shim 3、CRI-Containerd 4、CRI-O 5、Containerd (三)Docker 简介…

C练习——判断三角形并求面积

题目:从健盘任意输入三角形的三边长为a,b,c,编程判断a,b,c的值能否构成一个三角形,若能构成三角形,则计算并输出三角形的面积,否则提示不能构成三角形。 已知构成三角形的条件是:任意两边之和大于第三边。 解析&#…

《深入理解JAVA虚拟机笔记》垃圾回收器

JVM 判定 Java 对象是否为垃圾的方法 引用计数算法 很多教科书判断对象是否存活的算法是这样的: 在对象中添加一个引用计数器,每当有一个地方引用它时,计数器值就加一;当引用失效时,计数器值就减一;任何时刻计数器为…

想要学会JVM调优,先掌握JVM内存模型和JVM运行原理

1、前言 今天将和你一起探讨Java虚拟机(JVM)的性能调优。 JVM算是面试中的高频问题了,通常情况下总会有人问到:请你讲解下 JVM 的内存模型,JVM 的 性能调优做过? 2、为什么 JVM 在 Java 中如此重要 首…

使用electron属性实现保存图片并获取图片的磁盘路径

在普通的网页开发中,JavaScript由于安全性的考虑,通常是无法直接获取到客户端的磁盘路径的。浏览器出于隐私和安全原因对此类信息进行了限制。 在浏览器环境下,JavaScript主要通过Web APIs来与浏览器进行交互,而这些API通常受到浏…

C语言实现将不同数字组成无重复的三位数【一题一策】第一期

问题:有1、2、3、4共4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少? 一、题目分析 1123124132134142143221321423124123424333123143213413243424412413421423431432 我们经过排列组合,判断共能组成2…

cargo(rust包管理) 常见命令、包检索 (windows+linux)

rust环境和开发环境配置:rust开发环境配置 winlinux Cargo是Rust的构建系统和包管理器。 如果你的能力足够强也愿意,可以不用cargo进行rust开发,即从头开始敲代码 一、cargo包相关查询 1.查找包 查找cargo包链接:crates.io …

RAID的介绍和选择

RAID 类型:什么是 RAID 以及哪种 RAID 级别适合您? 一、RAID 简介 在2021年6月11日,亚瑟迪特纳进行了一场关于RAID技术的技术讲座。RAID,即独立磁盘冗余阵列,是将多个硬盘驱动器协同工作的技术。不同的RAID类型各有优…

STM32——通用计时器

通用计时器框图 1.时钟源 1)内部时钟(CK_INT) 2)外部时钟模式 1:外部输入引脚(TIx),x1,2(即只能来自于通道 1 或者通道 2) 3)外部时钟模式 2:外部触发输入(ETR) 4&#…

STM32实战之IAP代码升级

目录 1 IAP介绍 2 内存分区 3 整体设计流程图 4 Boot Loader的代码编写 5 APP1代码编写 6 APP2代码编写 stm32内部flash操作相关函数 1 IAP介绍 IAP(In Application Programming)即在应用编程, IAP 是用户自己的程序在运行过程中…

解决IDEA 不能正确识别系统环境变量的问题

问题描述 本人laptop 上的是设置了GOOGLE_APPLICATION_CREDENTIALS 这个环境变量的, 正常java or python 的程序能基于这个环境变量使用 某个gcp service account 去访问GCP的资源 [gatemanmanjaro-x13 ~]$ env | grep -i google GOOGLE_APPLICATION_CREDENTIALS/…