如何学习VBA:3.2.8 OnTime方法与OnKey方法

我给VBA的定义:VBA是个人小型自动化处理的有效工具。利用好了,可以大大提高自己的劳动效率,而且可以提高数据处理的准确度。我推出的VBA系列教程共九套和一部VBA汉英手册,现在已经全部完成,希望大家利用、学习。

如果您只是一般的职场VBA需求,可以打包选择7.1.3.9教程+汉英手册,第7套教程是入门,第1套教程是入门后的提高,第3套教程字典是必备的VBA之精华,第9套教程是实用的典型案例讲解。这四套教程内容掌握后足以处理一般工作中的问题,实际写代码的时候再辅助代码汉英手册,足矣!如果您想进一步提高,就需要选择高级阶段的教程了。

VBA是面向对象编程的语言,博大精深。很多朋友咨询VBA的学习方法,我会陆续给大家讲解一些我的经验,大家可以慢慢体会。今日的内容是:如何学习VBA:3.2.8 OnTime方法与OnKey方法957c1d944a33829ff4efb371a631016c.jpeg

【分享成果,随喜正能量】内心的美,如空谷幽兰,洋溢阵阵芬芳,使人心情愉悦。学道的人,须重视内在的修持,不以华丽的衣着来装饰自己,而以高贵气质来涵育自己,以道德修养来庄严自己。。

3.2.8 OnTime方法与OnKey方法

对于这两个方法,我们先看一下介绍:Application对象的OnTime方法能够安排一个过程在将来的特定时间运行,Application 对象的OnKey方法指定特定键或特定的组合键运行的过程。从介绍中我们可以看出,这两个方法是应用程序对象的方法,一个的作用是安排某个过程的自动运行,一个是指定特定键的运行,两者都是安排某个过程的运行,只是前者是利用时间来控制,后者是利用键来控制。

在教程的讲解中,我们实现了利用OnTime方法来模拟一个计时器功能,在这个计算器中可以实现数字的秒级累加,大家在学习的过程中要理解这种方法的应用:

Sub mynz_31_1() '利用VBA代码实现"定时器"功能

  Sheets("31").Cells(1, 2) = Sheets("31").Cells(1, 2) + 1

  Application.OnTime Now + TimeValue("00:00:01"), "mynz_31_1"

End Sub

Sub mynz_31_2() '利用VBA代码实现"定时器"功能

 On Error GoTo 100

   Application.OnTime Now + TimeValue("00:00:01"), "mynz_31_1", , False

   Sheets("31").Cells(1, 2) = 0

   Exit Sub

100:

   MsgBox "请先按[ON]按钮!"

End Sub

上面的代码是设置开始和关闭的按钮,这里给大家提出一个思考题:上述代码中利用了错误语句来处理程序运行过程点击关闭按钮的功能,这种方案有哪些不足?有没有更好的方案呢?请学员思考一下,可以考虑控件的属性及全局变量的应用。

在onkey讲解的实例中,我们利用了这个方案来处理屏蔽某些按钮的功能,这是这个方法的实用之处,这里仅提醒大家要注意代码的书写位置。同时要注意在关闭应用程序时务必恢复原貌。上述的两点也是我们在理解代码位置时确实应该注意的,什么是标准模块,什么是私用模块。同时要理解在工作簿模块中各个事件的含义。

eae6bd3453f2dc2f2c5bf65cb7855ec2.jpeg

学习VBA是个经验积累的过程,遇到什么问题,该如何处理,自己要把握好,同时每位学员要掌握VBA的基本概念。在我的答疑过程中,有的学员虽然学习到了高级教程,但是一些基本的术语都还没有掌握,提的问题自己都描述不清楚。计算机语言玩的是逻辑关系,当你的程序报错时,要提供哪里报错了?提示是什么?这是基本的描述,不能说“老师,我的程序有问题,您给我看看”,要知道,读别人的代码还不如自己写代码,我要求学员提供自己的报错程序,报错代码位置,报错提示,以方便错误的追踪。要有逻辑关系的表述能力,如果提供的程序没有报错,而是让我去找测试,那的确不是VBA学习之正途。

f58f2b7dc756ce5f3b9b59902952f5b6.jpeg

我20多年的VBA实践经验,全部浓缩在下面的各个教程中:


6f9df598975daf6d90faea75a05bc368.jpeg

fa09825c79722d109a59d01b7c372e08.jpeg

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

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

相关文章

System-V共享内存和基于管道通信实现的进程池

文章目录 一.进程间通信:进程间通信的本质: 二.Linux管道通信匿名管道:关于管道通信的要点:基于匿名管道构建进程池: 三.System-V共享内存共享内存和命名管道协同通信 参考Linux内核源码版本------linux-2.4.3 一.进程间通信: 操作系统中,为了保证安全性,进程之间具有严格的独…

Jquery ajax 进行网络请求,同步阻塞引起的UI线程阻塞 (loading图片不显示 )

jax重新获取数据刷新页面功能,因为ajax属于耗时操作,想在获取数据且加载页面时显示加载遮罩层,结果发现了ajax的好多坑。 ajax 执行http网络请示时时,让遮罩层显示,ajax加载完毕后遮罩层消失。 因为我想让loadChart()…

LeetCode算法题解|474. 一和零

474. 一和零 题目链接:474. 一和零 题目描述 给你一个二进制字符串数组 strs 和两个整数 m 和 n 。 请你找出并返回 strs 的最大子集的长度,该子集中 最多 有 m 个 0 和 n 个 1 。 如果 x 的所有元素也是 y 的元素,集合 x 是集合 y 的 子…

c++模板模板参数,可变数量的模板参数

当使用模板模板参数时&#xff0c;我们可以将一个模板作为另一个模板的参数&#xff0c;从而实现更大的灵活性和重用性。模板模板参数的主要优势之一是它允许我们编写适用于多种模板类型的通用代码。 下面是一些关于模板模板参数的更多信息 template <template <typenam…

外贸独立站外部优化:提升网站可见度与吸引力的策略

随着全球电子商务的快速发展&#xff0c;外贸独立站已经成为众多企业拓展海外市场、提升品牌影响力的关键工具。然而&#xff0c;要想在竞争激烈的外贸市场中脱颖而出&#xff0c;除了产品优质、服务周到外&#xff0c;还需要做好网站的外部优化工作。本文将详细探讨如何通过有…

卷积神经网络(CNN)识别验证码

文章目录 一、前言二、前期工作1. 设置GPU&#xff08;如果使用的是CPU可以忽略这步&#xff09;2. 导入数据3. 查看数据4.标签数字化 二、构建一个tf.data.Dataset1.预处理函数2.加载数据3.配置数据 三、搭建网络模型四、编译五、训练六、模型评估七、保存和加载模型八、预测 …

Ubuntu18.04安装A-Loam保姆级教程

系统环境&#xff1a;Ubuntu18.04.6 LTS 1.A-Loam的安装前要求&#xff1a; 1.1 ROS安装&#xff1a;参考我的另一篇博客 Ubuntu18.04安装ROS-melodic保姆级教程_灬杨三岁灬的博客-CSDN博客还是那句话&#xff0c;有时候加了这行也不好使&#xff0c;我是疯狂试了20次&#…

十六、互斥量

互斥量的目的就是为了实现互斥访问。 1、概述 (1)举例说明&#xff1a; 怎么独享厕所&#xff1f;自己开门上锁&#xff0c;完事了自己开锁。 你当然可以进去后&#xff0c;让别人帮你把门&#xff1a;但是&#xff0c;命运就掌握在别人手上了。 …

3.3.2 深度理解BITS_TO_LONGS函数

文章目录 定义物理意义内核应用应用一:直接使用应用二 间接使用测试驱动层示例应用层示例参考定义 BITS_TO_LONGS定义在include/linux/bitops.h中,具体如下 #define BITS_PER_BYTE 8 #define

Task.Run为什么会存在内存泄漏的风险?

由于值类型是拷贝方式的赋值&#xff0c;捕获的本地变量和类成员是指向各自的值&#xff0c;对本地变量的捕获不会影响到整个类。但如果把类中的值类型改为引用类型&#xff0c;那这两者最终指向的是同一个对象值&#xff0c;这是否意味着使用本地变量还是无法避免内存泄漏&…

【java】-D参数使用

在开发过程中我们使用开源工具经常会用到在启动命令时候加入一个 -Dxxx 类型的参数。到底-Dxxx是干什么用的了。 官方文档 地址&#xff1a;文档地址 java命令使用 下面是来源于官方文档&#xff1a; java [options] classname [args] java [options] -jar filename [args…

FFmpeg零基础学习(二)——视频文件信息获取

目录 前言正文一、获取宽高信息1、核心代码2、AVFormatContext3、avformat_alloc_context4、avformat_open_input5、avformat_find_stream_info6、av_dump_format7、av_find_best_stream End、遇到的问题1、Qt Debug模式avformat_alloc_context 无法分配对象&#xff0c;而Rele…

2023年汉字小达人市级比赛在线模拟题的使用顺序、建议和常见问题

今天是2023年11月25日&#xff0c;星期六&#xff0c;上午举办了2023年第八届上海小学生古诗文大会的复选活动&#xff08;复赛&#xff09;&#xff0c;结束了复选活动&#xff0c;很多学霸孩子们马上就开始投入到第十届汉字小达人的市级活动&#xff08;市级比赛&#xff09;…

PCL 计算两点云之间的最小距离

目录 一、 算法原理二、 代码实现三、 结果展示四、 相关链接本文由CSDN点云侠原创,原文链接。如果你不是在点云侠的博客中看到该文章,那么此处便是不要脸的爬虫与GPT。 一、 算法原理 pcl::registration::CorrespondenceEstimation是确定目标和查询点集(或特征)之间对应关…

【Web】CmsEasy 漏洞复现

访问主页 到处点一点没啥发现 扫目录 访问/admin 账号密码都是admin admin,不知道为什么&#xff0c;这里就先当作是默认吧 &#xff08;其实都是信息检索&#xff0c;能在网上搜到就行hhh&#xff09; 登录成功 看到左边列表有模板&#xff0c;心里大概有数了哈 进行一波历…

Android虚拟化

一、开源项目 开源的项目有一些&#xff0c;比如完全虚拟化的&#xff1a; twoyi 两仪由两部分组成&#xff1a;两仪 App&#xff0c;它实际上是一个 UI 渲染引擎&#xff0c;两仪内部运行的 ROM。 但是看telegram和github&#xff0c;这个app没有完整开源&#xff0c;并且最近…

二维列表如何利用set()进行去重

一维列表去重 输入&#xff1a; a[1,2,3,4,5,6,6] print(a) print(type(a)) bset(a) print(b) 输出&#xff1a; [1, 2, 3, 4, 5, 6, 6] <class list> {1, 2, 3, 4, 5, 6} 代码显示一维列表去重是没有问题的 二维列表去重 输入&#xff1a; a[[1,2,3,],[4,5,6],[…

StarRocks Evolution:One Data,All Analytics

在 11 月 17 日举行的 StarRocks Summit 2023上&#xff0c;StarRocks TSC Member、镜舟科技 CTO 张友东详细介绍了 StarRocks 社区的发展情况&#xff0c;并全面解析了 StarRocks 的核心技术与未来规划&#xff1b;我们特意将他的精彩演讲整理出来&#xff0c;以帮助大家更深入…

Typescript的数据类型

Typescript Typescript 是 Javascript 的一个超集。 Typescript 在原有 js 的基础之上又添加了编译期的类型检查的功能。意味着如 果在ts 的环境下开发时&#xff0c;会对变量的数据类型进行较为严格的验证&#xff0c;防止程序员写出可能出问题的代码&#xff0c;规范编程习惯…

docker环境安装

环境 主机环境 1. 宿主机环境 ubuntu-22.04.3-live-server-amd64 &#xff0c;下载地址&#xff1a; https://mirrors.aliyun.com/ubuntu-releases/22.04.3/ubuntu-22.04.3-live-server-amd64.iso 2. apt 包管理器&#xff0c;镜像源修改 : 将 http://cn.archive.ubunt…