博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
foreach 循环达到条件的第一次就停止_Excel VBA新手学习笔记 基础循环控制论
阅读量:30592 次
发布时间:2020-01-05

本文共 1490 字,大约阅读时间需要 4 分钟。

作者 : 金人瑞(郑广学Excel VBA 175例实战教程学员)

06509eec84760647dc0a31d4eea753ae.png

老师教程中的循环流程图

最近正在学习郑广学老师的VBA 175例教程(私信回复175),本文是新手整理出来的笔记,虽然名字高大上但内容多为基础,也难免有错误,希望大家批评指正。

循环基础1>>循环的种类与解释

1.1 数值型变量循环

写法为For i = …to …/next 循环变量一般为数值且知道具体对象,步长值(step)为1的时候可省略不写,为负数时是倒着循环,删除空白单元格的时候通常是倒着循环

990b0e97687ab38477d58bc59d3b7a53.png

721159251da4be537dd7accec438d71a.png

左侧为代码,右侧为代码执行结果,这种循环的变量(i)一般是数值

1.2 对象型变量循环

写法为For each…/next 一般只知道对象种类和具体的范围,求出具体对象数量相对麻烦的时候使用

adde6ace35a714abf537e1d5bfeda877.png

ac226ad9bd8edd4151af00a360b158aa.png

左侧为代码,右侧为结果,我们可以通过执行结果看到for each/next 循环其实是按照先行后列的顺序执行的

1.3 动作型循环

写法DO while(until)…/loop和while…/wend三种,都是在省略号处写循环的启动或者终止条件,其中DO/loop循环中,while(until)可以放在do后面也可以放在loop后面 ,这样做的区别是do语句是第一次循环执行的前后做判断.

a60a044e2375be38be42ddde3deabceb.png

72a0016a8e8cf04ce3f334f74b32ead1.png

左侧代码,右侧结果,需要注意的是do循环的终止条件为i小于某个数值得时候必须加i= i+1这样的递推否则很容易会陷入死循环

循环基础2>>循环的推进原理

2.1 单路线连接型循环

3406cf802871624e943b8a9552d8da56.png

e0b502afb646a59c61f362c139805028.png

上面代码,下面结果:两套循环系统,互不干涉,在写代码时一定要思考清楚需要几个循环系统,是否循环需要分开

2.2 单路线包裹型循环

上面的实例可以改造,变成包裹型循环,具体写法是for(for each)循环中套一层for(for each)循环

86ca306f0cecf9ebde5f57b00595597a.png

eda2f12bed11de5e11cb8a6244a4454c.png

上面代码,下面结果,一般情况下,包裹型循环单元格的特点很类似for each循环单元格,只不过for each循环是先选择循环每一行的区域,选定行以后再循环该区域内的每一个单元格,可以参考上面的for each循环,而循环包循环则可以先选择列来循环,再循环每一列区域内的单元格.

2.2 多路并进循环

这将是本文的重点,写法是在任意一个循环进程内写入if判断语句,符合判断则累加推进另外一个进程

实例图片以及说明

ecd4261f981fc0fbb99f63898e92e614.png

我们要把每一个质检员的结果填入下表,但是又不能留有空格.这个时候我们就可以设计一个多路并进的循环结构.详情看代码以及注释

a17eb908c6dc31e61db1d1faf1cd194c.png

e30b6c54eb29098678c4b786f118a382.png

代码中我们可以看到多路并进其实是利用已知的循环控制未知的路线过程.

补充:退出循环可以用if判断,符合条件使用exit for 语句就行(exit do).这里不再多整理,但是需要提到的是,一般不建议使用goto语句,很容易把自己搞晕

最后说一点学习VBA的经历希望对新人有用

一开始也是找各种免费课,速成课,看完速成课的最大结果其实是他给的案例你会,你自己的案例不会,还不容易百度到了吧,黄花菜都老了,这不是VBA应该有的效率,我要的是高效率,不仅快捷还要方便。于是我在QQ阅读买了书,又买了纸质书!加了群,可还是那样,书里面只带你入门,他写的很多我都会,不会的也看不懂,场面一度极其尴尬。究竟什么是提高?究竟如何才能提高?这两个问题直到我在b站看到了郑老师我才反应过来,真正的高手是能在一瞬间就有思路怎样去处理数据,也能在很短的时间里面调用写好的模块。这才是真正的高效率。这也恰恰是这么长时间我在其他课程里面没听到的东西,虽然前面走了很多弯路,不过这一个月来我每天上厕所都要看老师的视频,VBA水平突飞猛进,学习上瘾的这种感觉,比打游戏上瘾还强烈!!!

转载地址:http://nmzsdu.baihongyu.com/

你可能感兴趣的文章
用thttpd做Web Server
查看>>
服务器端开发经验总结 Linux C语言
查看>>
将网站程序放在tmpfs下
查看>>
使用Nginx的proxy_cache缓存功能取代Squid
查看>>
nginx 反向代理,动静态请求分离,proxy_cache缓存及缓存清除
查看>>
nginx 的proxy_cache才是王道
查看>>
Nginx proxy_cache 使用示例
查看>>
Nginx源代码分析 - 日志处理
查看>>
使Apache实现gzip压缩
查看>>
Memcached在大型网站中应用
查看>>
Hadoop简要介绍
查看>>
squid中的X-Cache和X-Cache-Lookup的意义
查看>>
squid 优化指南
查看>>
centos vnc配置笔记
查看>>
让Squid 显示本地时间
查看>>
linux mysql 命令 大全
查看>>
清除Squid缓存的小工具
查看>>
Varnish Cache 3.0.0安装
查看>>
2011年6月编程语言关注度排行
查看>>
Varnish使用小结
查看>>