VBA宏编程_宏代码怎么用

VBA宏编程_宏代码怎么用背景Office的编程语言较老,和现有高级语言相差较多,导致入门以及编写差异较大,编写和调试不方便,所以一直没考虑过使用VBA进行Office编程,但最近有个需求,是在无高级编程语言环境的内网主机上进行表格自动化处理,所以必须得用表格自带函数实现简单逻辑以及VBA实现复杂逻辑。…

大家好,又见面了,我是你们的朋友全栈君。

背景

Office的编程语言较老,和现有高级语言相差较多,导致入门以及编写差异较大,编写和调试不方便,所以一直没考虑过使用VBA进行Office编程,但最近有个需求,是在无高级编程语言环境的内网主机上进行表格自动化处理,所以必须得用表格自带函数实现简单逻辑以及VBA实现复杂逻辑。

需求

对A和B进行m次评分,计算A和B的最终评分。计算逻辑:不是去掉A和B各自的最高分和最低分,而是计算A-B差值的最高分和最低分(负值),去掉这两组数据对应的A和B的两组评分后,剩下的m-2次评分求均值,得到A和B的评分。
特殊情况:若A-B恒等于const,则算法需要考虑去掉评分后可能只去掉了一组评分,因为按照匹配算法来说,先后顺序匹配到了就认为是匹配到了,而不去判断去掉的两组评分是否是同一组。

VBA代码

请添加图片描述
请添加图片描述

总结

Excel比较老了,所以编程方法与高级语言相差较大,写程序不好写,比如数组是1开始索引,圆括号而非方括号取索引,类似matlab,取数组的值需要raw4(r,1)不能raw4®;
VBA是Office留下来的接口,对于复杂逻辑、自动化处理有用;
简单的逻辑还是使用Excel自带的内置函数实现,更好理解,缺点是只能写一行函数。
wps的宏启动需要联网,所以内网下启动不了宏;
Excel2003 支持宏运行,录制宏开始后进行表格操作,然后停止录制,点进去选择宏后编辑,进入IDE环境,可自动生成对应的VBA代码,可以参考,F1帮助手册;
pandas可以读取Excel进行精确的复杂逻辑操作。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/135462.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • android高德地图获取海拔_高德导航地图能显示海拔高度吗

    android高德地图获取海拔_高德导航地图能显示海拔高度吗现在人们生活水平普遍提高,私家车成为老百姓的常态,选择周末或者节假日来一场自驾游还是非常给力的,很多年轻人都喜欢挑战自己,去西部自驾游,这个就需要知道海拔信息了,那么高德地图能导航出海拔数据吗?高德地图测海拔的具体方法如下:1、第一步打开高德地图的网页,找到并点击下方那行小字。2、点中间的(开放平台)四个字。3、打开高德开发平台界面然后依次点击(开发支持)-(地图工具)-(坐标拾取器)。4、打开界…

    2022年5月21日
    434
  • bat启动命令行_cmd打开bat文件

    bat启动命令行_cmd打开bat文件写了个win环境本地启动的java项目,又不想每次去win+R再开启powershell(win10环境)所以百度了一下bat脚本参考了大佬的文章:https://www.cnblogs.com/LiuYanYGZ/p/12078984.html只需要简单的命令就可以了:startcmd/kechoHello,World!##执行完毕以后,新开的窗…

    2022年9月23日
    2
  • 一维卷积神经网络的理解是什么_卷积神经网络的输入

    一维卷积神经网络的理解是什么_卷积神经网络的输入设输入的数据维度是BxSxT一维卷积神经网络在维度S上进行卷积如下,设置一维卷积网络的输入通道为16维,输出通道为33维,卷积核大小为3,步长为2#in_channels:16#out_channels:33#kernel_size:3m=nn.Conv1d(16,33,3,stride=2)input=torch.randn(20,16,50)output=m(input)#shapeofoutputis([20,33,24

    2022年9月22日
    1
  • 5g 网络切片 边缘计算_5g网络切片技术前景

    5g 网络切片 边缘计算_5g网络切片技术前景紧接上文接入网RANRAN切片提供了基于切片ID的AMF/UPF选择,并提供了相对静态的资源控制和优先级控制。此外,RAN通过RIC(RANIntelligentControl,通过E2接口连接gNB)实现了针对动态资源调度和优先级控制等的实时闭环控制。关于RAN切片的基本机构可参照下图优先级控制在未适用网络切片前,显然,gNB并不能针对UE的不同服务做不同的优先级控制。在适用了5G的网络切片后,运营商就能就能通过不同的网络切片在无线侧调度不同的优先级(这是显而易见的,哈哈)。譬如UE1用高优

    2022年9月26日
    3
  • Java液晶数字字体显示当前时间[通俗易懂]

    Java液晶数字字体显示当前时间[通俗易懂]Java液晶数字字体显示当前时间importjava.text.SimpleDateFormat;importjava.util.ArrayList;importjava.util.Date;importjava.util.HashMap;importjava.util.List;importjava.util.Map;/****@authorzdy…

    2025年6月30日
    3
  • DB2 递归查询_oracle递归查询所有子节点

    DB2 递归查询_oracle递归查询所有子节点以父子节点定义的表数据递归查询:DB2 递归查询WITH temp(id,parentid,level)    AS   ( SELECT id,parentid,0   FROM AMIS_WF_NODE WHERE parentid = ‘4028e48146a3c33d0146a3cd9e860022’  UNION ALL   SELECT b.id,b.pare

    2025年7月12日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号