Excel精英培训网

 找回密码
 注册
数据透视表40+个常用小技巧,让你一次学会!
查看: 1530|回复: 3

求组vba实现以下需求

[复制链接]
发表于 2019-9-2 13:14 | 显示全部楼层 |阅读模式
用vba判断选定区域是否含有“是”值,
 楼主| 发表于 2019-9-2 13:14 | 显示全部楼层
回复

使用道具 举报

发表于 2019-9-2 13:44 | 显示全部楼层
vba的find可以直接查找,这个函数我从来没用过,不会用它,所以我就写一段普通的循环查询供参考:
Dim rng As String
Dim rg As Range
rng = Range("b1")     ’在b1输入自选区域,如c1:f30,要从c列往后选,a-b列被用来存储单元格地址了
hs = 2                      '记录查找的起始区域,b1是自定义区域,所以从第二行开始记录
For Each rg In Range(rng)
    If rg.Value = "是" Then
      Cells(hs, 1) = "找到了"         '在hs行的第一列A列记录“找到了”
      Cells(hs, 2) = rg.Address      '在hs行的第二列B列记录单元格地址
      hs = hs + 1                        'hs+1,用来记录下一个找到的单元格地址
    End If
Next
回复

使用道具 举报

发表于 2019-9-2 17:01 | 显示全部楼层
  1. Sub test()
  2. Dim rng As Range
  3. Set rng = Selection.Find("是")
  4. If Not rng Is Nothing Then MsgBox "Yes"
  5. End Sub
复制代码

评分

参与人数 1学分 +3 收起 理由
lsyylw + 3 太强大了

查看全部评分

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|Archiver|Excel精英培训 ( 豫ICP备11015029号 )

GMT+8, 2024-4-27 00:50 , Processed in 0.393940 second(s), 13 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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