vbfor循环语句详解(vb foreach循环用法)

vbfor循环语句详解(vb foreach循环用法)V BA 之 Excel 应用 版权 是非常经典的 是我推出的第七套教程 定位于初级 目前是第一版修订 这套教程从简单的录制宏开始讲解 一直到窗体的搭建 内容丰富 实例众多 大家可以非常容易的掌握相关的知识 这套教程共三册 十七章 都是我们在利用 E XCEL 工作过程中需要掌握的知识点 希望大家能掌握利用 今日讲解的内容是 V BA 之 Excel 应用第三章第三节 遍历工作薄和工作表 For Each 循环的利用 上 分享成果 随喜正能量 命是什么



《VBA之Excel应用》(版权10178983)是非常经典的,是我推出的第七套教程,定位于初级,目前是第一版修订。这套教程从简单的录制宏开始讲解,一直到窗体的搭建,内容丰富,实例众多。大家可以非常容易的掌握相关的知识,这套教程共三册,十七章,都是我们在利用EXCEL工作过程中需要掌握的知识点,希望大家能掌握利用。今日讲解的内容是:VBA之Excel应用第三章第三节:遍历工作薄和工作表(For Each循环的利用)(上)

VBA之Excel应用第三章第三节:遍历工作薄和工作表(For Each循环的利用)(上)_数组



【分享成果,随喜正能量】命是什么?命是一个人活着的根基,是一切的前提,万般皆是命,半点不由人。人的一生,求求不来寿,争争不过命。只有生命在,才能活好每一天。

家是什么?家是一个人的牵挂,是一个人内心深处最柔软的地方,也是每一个灵魂的归处,人这一辈子,家庭和睦,父母安康,夫妻和美,子女懂事,就是最大的幸福。。


大家好,我们今日开始讲解工作簿(Workbook)和工作表(Worksheet)对象(Object),我们经常讲的面向对象编程,这里的工作表和工作簿就是所谓的对象。对象是一个名词,每个对象有着自己的属性和方法。这些属性和方法就是我们要利用的工具。这个章节中我们将讲解到对象的层次结构、集合属性和方法,同时还会讲解到工作簿的打开和关闭以及工作表的循环处理。由于这套教程是针对EXCEL而写的,所以这章内容非常重要。

VBA之Excel应用第三章第三节:遍历工作薄和工作表(For Each循环的利用)(上)_定义类_02


大家好,我们在这讲中将讲解遍历循环语句,这种语句在VBA代码中利用的十分普遍,也是我们在VBA代码中经常利用的三种循环语句之一:For Each循环。下面我们将看到Excel vba中的一个程序,它遍历循环所有打开的工作簿和工作表,并显示所有的名称。

语法:

For Each element In group
[ statements ]
[ Exit For ]
[ statements ]
Next [ element ]


参数:

1element 必需。用于循环访问集合或数组的变量。对于集合,element只能为Variant变量、通用对象变量或任何特定的对象变量。对于数组,element仅可是Variant变量。

2group 必需。对象集合或数组(用户定义类型除外)的名称

3statements 可选。在每个项目上执行的一个或多个语句。


注意点:


  • 如果group中有至少一个元素,则进入“For Each”循环。在进入循环后, 循环中的所有语句都将对group中的每一个元素执行。如果group中有多个元素,则继续为每个元素执行循环中的语句。group中不再有元素时,退出循环并继续执行“Next”语句后的语句。
  • 可以将任意数量的Exit For语句作为另一种退出方式放置在循环中的任何位置。"退出" 通常在评估某些条件后使用, 例如,if…then…, 将执行下一个紧接着的语句。
  • 可通过将“For Each...Next”循环放置在另一个该循环内来嵌套“For...Each...Next”循环。 但是,每个循环element必须是唯一的。
  • 如果忽略Next [ element ]语句中的[ element ],循环一样继续执行。不可随用户定义类型的数组一起使用“For Each...Next”语句,因为“Variant”不可包含用户定义类型。

下面代码中,我们将利用“For Each...Next”语句遍历所有打开的工作薄和每个工作薄的工作表的名称。


Sub mynzH() '遍历循环

Dim book As Workbook, sheet As Worksheet, text As String

For Each book In Workbooks

text = text & "Workbook: " & book.Name & vbNewLine & "Worksheets: " & vbNewLine

For Each sheet In book.Worksheets

text = text & sheet.Name & vbNewLine

Next

text = text & vbNewLine

Next

MsgBox text

End Sub


代码截图:

VBA之Excel应用第三章第三节:遍历工作薄和工作表(For Each循环的利用)(上)_定义类_03



代码讲解:

1Dim book As Workbook, sheet As Worksheet, text As String 这句是对变量的声明,声明booksheettext分别为WorkbookWorksheetString

2For Each sheet In book.Worksheets

text = text & sheet.Name & vbNewLine

Next

以上是内层循环,将提取每个工作表的名称。

3 For Each book In Workbooks

text = text & "Workbook: " & book.Name & vbNewLine & "Worksheets: " & vbNewLine

。。。。。

text = text & vbNewLine

Next

以上是外层循环讲提取每个工作薄的名称。

4) MsgBox text

将弹出一个对话框,告诉用户提取的内容。


  • 注意:可以使用&运算符连接(联接)元素。若要开始新行,可以使用vbNewLine。



待续



本讲内容参考程序文件:工作簿03.xlsm

VBA之Excel应用第三章第三节:遍历工作薄和工作表(For Each循环的利用)(上)_VBA_04




我20多年的VBA成果全在下面的资料中:


VBA之Excel应用第三章第三节:遍历工作薄和工作表(For Each循环的利用)(上)_VBA_05


VBA之Excel应用第三章第三节:遍历工作薄和工作表(For Each循环的利用)(上)_VBA_06








编程小号
上一篇 2025-03-06 09:30
下一篇 2025-01-29 13:06

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/bian-cheng-ri-ji/8987.html