ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
楼主: yuanzhuping

VBA常用技巧代码解析

    [复制链接]

TA的精华主题

TA的得分主题

 楼主| 发表于 2009-2-10 15:29 | 显示全部楼层

第1部分Range(单元格)对象

本帖已被收录到知识树中,索引项:开发帮助和教程
技巧5         查找单元格
5-1        使用Find方法
       在Excel中使用查找对话框可以查找工作表中特定内容的单元格,而在VBA中则使用Find方法,如下面的代码所示。
  1. #001  Sub RngFind()
  2. #002      Dim StrFind As String
  3. #003      Dim Rng As Range
  4. #004      StrFind = InputBox("请输入要查找的值:")
  5. #005      If Trim(StrFind) <> "" Then
  6. #006          With Sheet1.Range("A:A")
  7. #007              Set Rng = .Find(What:=StrFind, _
  8. #008                              After:=.Cells(.Cells.Count), _
  9. #009                              LookIn:=xlValues, _
  10. #010                              LookAt:=xlWhole, _
  11. #011                              SearchOrder:=xlByRows, _
  12. #012                              SearchDirection:=xlNext, _
  13. #013                              MatchCase:=False)
  14. #014              If Not Rng Is Nothing Then
  15. #015                  Application.Goto Rng, True
  16. #016              Else
  17. #017                  MsgBox "没有找到该单元格!"
  18. #018              End If
  19. #019          End With
  20. #020      End If
  21. #021  End Sub
复制代码
代码解析:
       RngFind过程使用Find方法在工作表Sheet1的A列中查找InputBox函数对话框中所输入的值,并查找该值所在的第一个单元格。
       第6到第13行代码在工作表Sheet1的A列中查找InputBox函数对话框中所输入的值。应用于Range对象的Find方法在区域中查找特定信息,并返回Range对象,该对象代表用于查找信息的第一个单元格。如果未发现匹配单元格,就返回Nothing,语法如下:
expression.Find(What, After, LookIn, LookAt, SearchOrder, SearchDirection, MatchCase, MatchByte, SerchFormat)
       参数expression是必需的,该表达式返回一个Range对象。
       参数What是必需的,要搜索的数据,可为字符串或任意数据类型。
       参数After是可选的,表示搜索过程将从其之后开始进行的单元格,必须是区域中的单个单元格。查找时是从该单元格之后开始的,直到本方法绕回到指定的单元格时,才对其进行搜索。如果未指定本参数,搜索将从区域的左上角单元格之后开始。
       在本例中将After参数设置为A列的最后一个单元格,所以查找时从A1单元格开始搜索。
       参数LookIn是可选的,信息类型。
       参数LookAt是可选的,可为XlLookAt常量的xlWhole 或xlPart之一。
       参数SearchOrder是可选的,可为XlSearchOrder常量的xlByRows或xlByColumns之一。
       参数SearchDirection是可选的,搜索的方向,可为XlSearchDirection常量的xlNext或xlPrevious之一。
       参数MatchCase是可选的,若为True,则进行区分大小写的查找。默认值为False。
       参数MatchByte是可选的,仅在选择或安装了双字节语言支持时使用。若为True,则双字节字符仅匹配双字节字符。若为False,则双字节字符可匹配其等价的单字节字符。
       参数SerchFormat是可选的,搜索的格式。
       每次使用Find方法后,参数LookIn、LookAt、SearchOrder 和MatchByte的设置将保存。如果下次调用Find方法时不指定这些参数的值,就使用保存的值。因此每次使用该方法时请明确设置这些参数。
       如果工作表的A列中存在重复的数值,那么需要使用FindNext方法或FindPrevious方法进行重复搜索,如下面的代码所示。
  1. #001  Sub RngFindNext()
  2. #002      Dim StrFind As String
  3. #003      Dim Rng As Range
  4. #004      Dim FindAddress As String
  5. #005      StrFind = InputBox("请输入要查找的值:")
  6. #006      If Trim(StrFind) <> "" Then
  7. #007          With Sheet1.Range("A:A")
  8. #008              Set Rng = .Find(What:=StrFind, _
  9. #009                              After:=.Cells(.Cells.Count), _
  10. #010                              LookIn:=xlValues, _
  11. #011                              LookAt:=xlWhole, _
  12. #012                              SearchOrder:=xlByRows, _
  13. #013                              SearchDirection:=xlNext, _
  14. #014                              MatchCase:=False)
  15. #015              If Not Rng Is Nothing Then
  16. #016                  FindAddress = Rng.Address
  17. #017                  Do
  18. #018                      Rng.Interior.ColorIndex = 6
  19. #019                      Set Rng = .FindNext(Rng)
  20. #020                  Loop While Not Rng Is Nothing And Rng.Address <> FindAddress
  21. #021              End If
  22. #022          End With
  23. #023      End If
  24. #024  End Sub
复制代码
代码解析:
       RngFindNext过程在工作表Sheet1的A列中查找InputBox函数对话框中所输入的值,并将查到单元格底色设置成黄色。
       第8行到第17行代码使用Find方法在工作表Sheet1的A列中查找。
       第16行代码将查找到的第一个单元格地址赋给字符串变量FindAddress。
       第18行代码将查找到的单元格底色设置成黄色。
       第19行代码使用FindNext方法进行重复搜索。FindNext方法继续执行用Find方法启动的搜索。查找下一个匹配相同条件的单元格并返回代表单元格的Range对象,语法如下:
expression.FindNext(After)
       参数expression是必需的,返回一个Range对象。
       参数After是可选的,指定一个单元格,查找将从该单元格之后开始。
       第20行代码如果查找到的单元格地址等于字符串变量FindAddress所记录的地址,说明A列已搜索完毕,结束查找过程。
       运行RngFindNext过程,在InputBox函数输入框中输入“196.01”后结果如所示。
使用FindNext方法重复搜索.jpg
       还可以使用FindPrevious方法进行重复搜索,FindPrevious方法的语法如下:
expression.FindPrevious(After)
       FindPrevious方法和FindNext方法唯一的区别是FindPrevious方法查找匹配相同条件的前一个单元格而FindNext方法是查找匹配相同条件的下一个单元格。

[ 本帖最后由 yuanzhuping 于 2009-2-16 22:06 编辑 ]

TA的精华主题

TA的得分主题

 楼主| 发表于 2009-2-10 15:40 | 显示全部楼层

第1部分Range(单元格)对象

技巧5         查找单元格
5-2        使用Like运算符
       使用Like运算符可以进行更为复杂的模式匹配查找,如下面的代码所示。
  1. #001  Sub RngLike()
  2. #002      Dim rng As Range
  3. #003      Dim a As Integer
  4. #004      a = 1
  5. #005      With Sheet2
  6. #006          .Range("A:A").ClearContents
  7. #007          For Each rng In .Range("B1:E1000")
  8. #008              If rng.Text Like "*a*" Then
  9. #009                  .Range("A" & a) = rng.Text
  10. #010                  a = a + 1
  11. #011              End If
  12. #012          Next
  13. #013      End With
  14. #014  End Sub
复制代码
代码解析:
       RngLike过程使用For Each...Next语句和Like运算符在单元格区域B1:E10000中搜索含有“a”字符的单元格,找到匹配单元格以后将单元格的值写入到A列中。
       第6行代码使用ClearContents方法清除A列区域的数据。
       第7行代码使用For Each...Next语句在单元格区域B1:E10000中循环。
       第8行代码使用Like运算符在单元格区域B1:E10000中搜索含有“a”字符的单元格。
       Like运算符用来比较两个字符串,语法如下:
result = string Like pattern
       参数string是必需的,字符串表达式。
       参数pattern是必需的,字符串表达式。
       如果string与pattern匹配,则result为True;如果不匹配,则result为False。但是如果string或pattern 中有一个为Null,则result 为 Null。
       参数pattern可以使用通配符、字符串列表或字符区间的任何组合来匹配字符串。表格中列出pattern中允许的字符以及它们与什么进行匹配。
pattern中的匹配字符串.jpg
       第9行代码将找到的匹配单元格的值写入到A列中。
       运行RngLike过程结果如图所示。
使用Like运算符进行模式匹配查找.jpg

[ 本帖最后由 yuanzhuping 于 2009-2-16 22:08 编辑 ]

技巧5 查找单元格.rar

76.04 KB, 下载次数: 5732

TA的精华主题

TA的得分主题

发表于 2009-2-10 15:50 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2009-2-10 15:52 | 显示全部楼层

第1部分Range(单元格)对象

技巧6         替换单元格内字符串
       如果需要替换单元格内指定的字符串,那么使用Range对象的Replace方法,如下面的代码所示。
  1. #001  Sub RngReplace()
  2. #002      Range("A1:A5").Replace "通州", "南通"
  3. #003  End Sub
复制代码
代码解析:
       RngReplace过程将工作表A1:A5单元格中的“通州”字符串替换成“南通”字符串。
       应用于Range对象的Replace方法替换指定区域内单元格中的字符,语法如下:
expression.Replace(What, Replacement, LookAt, SearchOrder, MatchCase, MatchByte, SearchFormat, ReplaceFormat)
       其中参数expression是必需的,返回一个Range对象。
       参数What是必需的,要搜索的字符串。
       参数Replacement是必需的,替换的字符串。
       运行RngReplace过程前工作表如图所示。
替换前单元格.jpg
       运行RngReplace过程后结果如图所示。
替换后单元格.jpg

[ 本帖最后由 yuanzhuping 于 2009-2-16 22:59 编辑 ]

技巧6 替换单元格内字符串.rar

7.11 KB, 下载次数: 3194

TA的精华主题

TA的得分主题

 楼主| 发表于 2009-2-10 16:28 | 显示全部楼层

第1部分Range(单元格)对象

技巧7         复制单元格区域
       在实际操作中,经常需要复制指定的单元格区域到另外一个单元格区域。要复制指定单元格区域到其他位置,使用Range对象的Copy方法,如下面的代码所示。
  1. #001  Sub RangeCopy()
  2. #002      Application.DisplayAlerts = False
  3. #003      Sheet1.Range("A1").CurrentRegion.Copy Sheet2.Range("A1")
  4. #004      Application.DisplayAlerts = True
  5. #005  End Sub
复制代码
代码解析:
       RangeCopy过程将如图所示的Sheet1工作表中A1单元格的当前区域复制到Sheet2工作表中以A1单元格为左上角单元格的区域。
需复制的数据表.jpg
       Sheet2工作表复制后如图所示。
复制结果.JPG
       Range对象的Copy方法的语法如下:
Copy(Destination)
       参数Destination表示复制单元格区域的目标区域,如果省略该参数,Excel将把该区域复制到剪贴板中。使用Copy方法复制单元格区域时,也复制了该单元格区域的格式。
       复制单元格区域时,如果目标区域为非空单元格区域,Excel将显示如图所示的消息框提示是否替换单元格内容,可以设置Application.DisplayAlerts属性值为False,使复制时不出现该消息框。
替换对话框.jpg
        第2行代码通常复制单元格区域的操作不会将单元格区域的列宽大小同时复制,如果希望在复制单元格区域的同时,也复制源区域的列宽大小,可以使用下面的代码。
  1. #001  Sub CopyWithSameColumnWidths()
  2. #002      Sheet1.Range("A1").CurrentRegion.Copy
  3. #003      With Sheet3.Range("A1")
  4. #004          .PasteSpecial xlPasteColumnWidths
  5. #005          .PasteSpecial xlPasteAll
  6. #006      End With
  7. #007      Application.CutCopyMode = False
  8. #008  End Sub
复制代码
代码解析:
        第4行代码使用Range对象的PasteSpecial方法选择性粘贴剪贴板中的Range对象的列宽。
        第5行代码粘贴剪贴板中的Range对象全部内容。
        第7行代码取消应用程序复制模式。
        应用于Range对象的PasteSpecial方法将剪贴板中的Range对象粘贴到指定区域,在粘贴时可以有选择的粘贴对象的部分属性。其语法如下:
PasteSpecial(Paste, Operation, SkipBlanks, Transpose)
        参数Paste指定要粘贴的区域部分,可为表格所列的XlPasteType常量之一。
XlPasteType 常量.jpg
        参数Operation指定粘贴操作。可为表格所列的XlPasteSpecialOperation常量之一。
XlPasteSpecialOperation常量.jpg
        参数SkipBlanks指示是否跳过空单元格,若参数值为True,则不将剪贴板上区域中的空白单元格粘贴到目标区域中。默认值为False。
        参数Transpose指示是否进行转置,若参数值为True,则粘贴区域时转置行和列。默认值为False。
        运行CopyWithSameColumnWidths过程后,Sheet3工作表如图所示,目标区域的各列列宽与源区域一致。
粘贴列宽后的复制结果.jpg
注意 使用PasteSpecial方法时指定xlPasteAll(粘贴全部),不会粘贴列宽。

[ 本帖最后由 yuanzhuping 于 2009-2-16 23:00 编辑 ]

技巧7 复制单元格区域.rar

10.07 KB, 下载次数: 3581

TA的精华主题

TA的得分主题

发表于 2009-2-10 16:29 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
班主,最近在想办法把日常office的工作通过vba实现,发现这个论坛正是我想要的。
想问一下斑竹:什么时候介绍一下如何使用vba实现动态修改图表(chart)中的数据源的方法?

TA的精华主题

TA的得分主题

 楼主| 发表于 2009-2-10 16:33 | 显示全部楼层
原帖由 henrych 于 2009-2-10 16:29 发表
班主,最近在想办法把日常office的工作通过vba实现,发现这个论坛正是我想要的。
想问一下斑竹:什么时候介绍一下如何使用vba实现动态修改图表(chart)中的数据源的方法?

在Shape(图形)与Chart(图表)对象这部分中有这方面的内容。

TA的精华主题

TA的得分主题

发表于 2009-2-10 16:40 | 显示全部楼层
班主,最近在想办法把日常office的工作通过vba实现。想问一下如何使用vba实现动态修改图表(chart)中的数据源?
即:有很多图表,每个图表的数据源都是来自各个不同SHEET中的相同的数据列,而各个SHEET中的数据行会定期自动追加,想通过VBA实现,点一个按钮,图表中的数据源就自动更新包含追加的数据。
劳烦斑竹指点一二,谢谢!

TA的精华主题

TA的得分主题

 楼主| 发表于 2009-2-10 16:42 | 显示全部楼层

第1部分Range(单元格)对象

技巧8         仅复制数值到另一区域
       如果在复制单元格区域时,仅希望复制单元格区域的数值,有下面几种方法。
8-1        使用选择性粘贴
       使用选择性粘贴功能并指定粘贴数值,如下面的代码所示。
  1. #001  Sub CopyPasteSpecial()
  2. #002      Sheet1.Range("A1").CurrentRegion.Copy
  3. #003      Sheet2.Range("A1").PasteSpecial Paste:=xlPasteValues
  4. #004      Application.CutCopyMode = False
  5. #005  End Sub
复制代码
代码解析:
       CopyPasteSpecial过程复制工作表Sheet1中A1单元格的当前区域的数值到工作表Sheet2的A1单元格所在区域中。
       第2行代码将如图所示的Sheet1中A1单元格的当前区域进行复制。
需复制的数据表.jpg
       第3行代码使用选择性粘贴功能并指定粘贴数值,选择性粘贴数值仅复制了单元格区域的数值,单元格区域的格式(背景颜色、字体对齐格式和边框等)不会被复制,复制结果如图所示。
复制单元格区域数值.jpg
8-2        直接赋值的方法
       除了使用Copy方法外,还可以使用直接赋值的方法,如下面的代码所示。
  1. #001  Sub GetValueResize()
  2. #002      With Sheet1.Range("A1").CurrentRegion
  3. #003          Sheet3.Range("A1").Resize(.Rows.Count, .Columns.Count).Value = .Value
  4. #004      End With
  5. #005  End Sub
复制代码
代码解析:
       GetValueResize过程将工作表Sheet1中的A1单元格的当前区域的数值赋予工作表Sheet3的A1单元格所在的单元格区域。
       在对单元格区域直接赋值时,应保证源区域大小与目标区域的大小一致,如果源区域为动态的单元格区域,可使用Resize方法确定目标区域。
       运行GetValueResize过程,赋值结果如上图所示。

[ 本帖最后由 yuanzhuping 于 2009-2-16 22:11 编辑 ]

技巧8 仅复制数值到另一区域.rar

10.37 KB, 下载次数: 3507

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2009-2-10 16:43 | 显示全部楼层
斑竹回复这么快啊,谢谢,我看看去。
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-9 00:54 , Processed in 0.044447 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表