Excel-VBA 快速上手(七、获取单元格对象)


一、单元格对象


单元格对象(Range)用来操作和控制工作表中的单元格,使用单元格对象可以设置单元格的格式、单元格的信
息,单元格的内容,选取单元格等,本文列举些常见的用法,最好动手试验一下,要记住灵活运用


二、获取单元格对象和选中单元格


2.1. 选中单个单元格


第一种方式,通过 Range(列名 + 行号).Select 选中单元格:

Public Sub main()
  Dim rng As Range
  Set rng = Range("A1")
  rng.Select
End Sub

第二种方式,通过 Cells(行号, 列名).Select 选中单元格:

Public Sub main()
  Dim rng As Range
  Set rng = Cells(1, "A")
  rng.Select
End Sub

2.2. 选中连续的单元格


1. 定位左上角和右下角,选中之间所有单元格

第一种方式,Range(左上角列名 + 左上角行号 : 右下角列名 + 右下角行号)

Public Sub main()
  Dim rng As Range
  '选中从A1到C10的所有单元格
  Set rng = Range("A1:C10")
  rng.Select
End Sub

第二种方式,Range(Cells(左上角行号,左上角列号), Cells(右下角行号,右下角列号))

Public Sub main()
  Dim rng As Range
  '选中从第一行第一列到第五行第六列的所有单元格
  Set rng = Range(Cells(1, 1), Cells(5, 6))
  rng.Select
End Sub

2. 以基准单元格位置为基础偏移选中

先找到一个用来做基准的单元格,再利用基准单元格对象的 Offset(偏移行数, 偏移列数) 函数来进行位置偏移

Public Sub main()
  Dim rng As Range
  Set rng = Range("A1:B10")
  '最终会选中D3到E12的所有单元格
  rng.Offset(2, 3).Select
End Sub

3. 以基准单元格位置为基础指定选中的行数和列数

先找到一个用来做基准的单元格,再使用单元格对象的 Resize(选中行数, 选中列数)

Public Sub main()
  Dim rng As Range
  Set rng = Range("A1")
  '以A1单元格为基础,向右选中五行三列,最终会选中A1到C5的所有单元格
  rng.Resize(5, 3).Select
End Sub

2.3. 选中多个不连续的单元格


第一种方式:

Public Sub main()
  Dim rng As Range
  Set rng = Range("A1,C1:F4,A7")
  rng.Select
End Sub

第二种方式:

Public Sub main()
  Dim rng As Range
  Set rng = Union(Range("A1"), Range("C1:F5"), Range("A7"))
  rng.Select
End Sub

2.4. 选中行


1. 选中单行

选中单行:通过 Rows(行号) 来选中指定行

Public Sub main()
  Dim rng As Range
  Set rng = Rows(1)
  rng.Select
End Sub

2. 选中连续行

Public Sub main()
  Dim rng As Range
  Set rng = Rows("1:10")
  rng.Select
End Sub

3. 选中多个不连续的行

Public Sub main()
  Dim rng As Range
  Set rng = Range("1:3,5:7")
  rng.Select
End Sub

4. 选中单元格所在的行

Public Sub main()
  Dim rng As Range
  Set rng = Range("C4:C5").EntireRow
  rng.Select
End Sub

2.5. 选中列


1. 选中单列

Public Sub main()
  Dim rng As Range
  Set rng = Columns(1)
  rng.Select
End Sub

2. 选中连续列

Public Sub main()
  Dim rng As Range
  Set rng = Columns("A:D")
  rng.Select
End Sub

3. 选中多个不连续的列

Public Sub main()
  Dim rng As Range
  Set rng = Range("A:B,D:E")
  rng.Select
End Sub

4. 选中单元格所在的列

Public Sub main()
  Dim rng As Range
  Set rng = Range("B1:C6").EntireColumn
  rng.Select
End Sub

2.6. 选中已使用单元格间的连续区域

Public Sub main()
  Dim rng As Range
  Set rng = Sheets(1).UsedRange
  rng.Select
End Sub

2.7. 单元格附近的连续区域


以基准单元格为中心点,在其上下、左右、左上、左下、右上、右下被使用的单元格都会被选中,然后以被选中的
单元格为基准,继续寻找每个选中单元格的上下、左右、左上、左下、右上、右下被使用的单元格,反复循环,直到
找不到被使用的单元格,最后以所选单元格的左上角和右下角为端点,将这一片区域全部选中

单元格附近的连续区域

如上图,基准单元格为 C7,它附近被使用的单元格有 C6、C8、B7、D7,所以这四个单元格会被选中,又因为 B6
与 B7 相邻,D8 与 D7 相邻,所以 B6 和 D8 也会被选中,最后以 B6 和 D8 为端点,选中所有区域

上图的代码为:

Public Sub main()
  Dim rng As Range
  Set rng = Range("C7").CurrentRegion
  rng.Select
End Sub

2.8. 多个单元格间的交集区域

Public Sub main()
  Dim rng As Range
  Set rng = Application.Intersect(Columns("b:c"), Rows("3:5"))
  rng.Select
End Sub

2.9. 定位单元格


在工作表中,我们可以用 Ctrl + G 调出定位窗口,然后设置定位条件来查找并选中单元格,如下图:

定位单元格

在 vba 中也提供了同样的功能来查找单元格,并获取单元格对象,语法为:单元格对象.SpecialCells(Type, Value)

SpecialCells 函数的参数其实就是为了对应上图中的选项,列举常用参数如下:

参数 Type 取值参数 Value 取值与上图选中对应的描述
xlCellTypeVisible不用传参可见单元格
xlCellTypeLastCell不用传参最后一个单元格
xlCellTypeBlanks不用传参空值
xlCellTypeConstants取值为:xlErrors、xlLogical、xlNumbers、xlTextValues常量
xlCellTypeFormulas取值为:xlErrors、xlLogical、xlNumbers、xlTextValues公式

SpecialCells 函数找不到匹配的单元格时会直接报错,如下图,所以实际使用时有必要考虑是否要使用 On Error Resume Next 来跳过错误,On Error Resume Next 在其他系列文章里有介绍:

错误1004
示例代码,定位 A1 到 A3 之间,设置了单元格格式为数字的单元格:

Public Sub main()
  On Error Resume Next
  Dim rng As Range
  Set rng = Range("A1:A3").SpecialCells(xlCellTypeFormulas, xlNumbers)
  rng.Select
  On Error GoTo 0
End Sub

2.10. 指定列中最后一个有内容的单元格

Public Sub main()
  Dim rng As Range
  '找到E列最后一行有内容的单元格
  Set rng = Range("E65536").End(xlUp)
  rng.Select
End Sub

  • 9
    点赞
  • 61
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: "excel-vba教程完全版.pdf"是一份非常详细的Excel VBA教程。它包含了许多实例和示例,解释了Excel VBA的基本概念和语法,以及如何使用VBA编写各种Excel宏。这份教程既适合初学者学习,也适合中级和高级用户作为快速参考手册使用。 该文档的存储位置是阿里云盘,这意味着你可以随时随地使用云盘进行访问。同样,这也意味着你可以下载该文档并将其保存到任何设备上,以便您在离线时仍然可以学习和参考。 无论你是需要学习Excel VBA来改进自己的工作,还是需要了解Excel VBA的基础知识作为一个数据处理或业务分析的工作要求,这个教程都非常优秀。如果你愿意花时间学习和实践,并跟随教程完成练习,你将成为一个熟练的Excel VBA程序员,能够编写更加复杂和高效的Excel宏。所以,这个教程是非常值得推荐的。 ### 回答2: excel-vba教程完全版.pdf是一本关于Excel VBA编程的教程,涵盖了许多内容,适合想要学习Excel VBA编程的初学者以及希望深入了解的进阶者。这本教程从基础概念开始,逐步深入,涵盖了VBA开发环境、数据类型、变量、运算符、控制结构、数组、函数等多个方面的内容。 此外,本教程还详细介绍了Excel VBA中常用的对象,如Workbook对象、Worksheet对象和Range对象等,以及它们的属性和方法的使用方式。同时,本教程还介绍了经典的Excel VBA编程技巧,如错误处理、调试技巧、宏录制等,让读者能够掌握高效、优化的编程方法。 总体来说,excel-vba教程完全版.pdf是一本较为全面的Excel VBA编程教程,对于Excel VBA编程感兴趣的人来说,是一本不可多得的学习资料。而作为阿里云盘上的一个资源,其存储空间也方便了用户在任何地方都可以随时下载和阅读,为Excel VBA编程爱好者提供了便利。 ### 回答3: excel-vba教程完全版.pdf是一份非常优秀的Excel VBA教程资源,非常适合希望学习如何使用Excel VBA编程的人。这份教程详细地介绍了VBA的各种基础和高级知识,包括如何使用VBA编写宏、创建用户界面以及使用各种对象、方法和属性等等。这份教程内容丰富、结构清晰、易于理解,对于初学者而言也非常友好。 在阿里云盘上获取这份教程也非常便捷和方便。用户只需要通过阿里云盘的下载链接即可下载教程文档,并可以在自己的电脑上进行阅读和学习。阿里云盘作为一种云存储服务,具有高速稳定、容量大等特点,因此不必担心下载速度和下载文件的稳定性问题。 总之,excel-vba教程完全版.pdf是一份非常优秀的VBA教程资源,对于想学习如何使用Excel VBA进行编程的人而言是一份极佳的教程材料。而且,通过阿里云盘可以轻松地获取这份教程资源,非常方便和实用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值