- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我对 vba 编码非常陌生,因为昨天才开始学习它,我对我在这里做错了什么有疑问。
我正在尝试编写一段代码,在某个范围内查找某个单词,检查相邻单元格上的值,在另一个范围内查找这些值,如果找不到,则执行一些操作,然后返回到寻找下一个匹配的第一个范围。
在插入第二个 .find 之前,我设法使循环正常工作,但是一旦添加它,它就会破坏循环吗?它给了我“运行时错误 91:未设置对象变量或 block 变量”。
我尝试从 Range
更改变量的数据类型至String
和来自 String
至Range
我已经尝试过Set variable =
只是variable =
对于变量
我已经发布了第二个.Find()
到达循环之前的变量
我移动了很多行
再说一遍,我对此很陌生,如果有人可以帮助我,我将非常感激
有问题的行是 Loop While cred.Address <> firstcred
它在第一个子例程中工作正常,但在第二个子例程中返回错误
sub subname1()
Dim credeb As Range
Dim cred As Range
Dim firstcred As String
Dim nome1 As Range
Dim data1 As Range
Set credeb = Range("credeb")
Set cred = credeb.find("crédito")
If cred Is Nothing Then
GoTo Final
Else
firstcred = cred.Address
Do
cred.Activate
Set nome1 = cred.Offset(0, -2)
Set data1 = cred.Offset(0, -1)
nome1.Interior.Color = vbYellow
data1.Interior.Color = vbYellow
Set cred = credeb.FindNext(cred)
Loop While cred.Address <> firstcred
End If
Final:
End Sub
______________________
Sub subname2()
Dim credeb As Range
Dim cred As Range
Dim firstcred As String
Dim nome1 As Range
Dim data1 As Range
Dim nome2 As Range
Dim nome11 As Range
Set credeb = Range("credeb") 'nome da tabela credito ou debito
Set cred = credeb.find("crédito")
Set nome2 = Range("nome2") 'nome da tabela de nomes do credito
If cred Is Nothing Then
GoTo Final
Else
firstcred = cred.Address
Do
cred.Activate
Set nome1 = cred.Offset(0, -2)
Set data1 = cred.Offset(0, -1)
Set nome11 = nome2.find(nome1)
If nome11 Is Nothing Then
nome1.Interior.Color = vbYellow
data1.Interior.Color = vbYellow
Set nome1 = Nothing
Set data1 = Nothing
Set nome11 = Nothing
End If
Set cred = credeb.FindNext(cred)
Loop While cred.Address <> firstcred
End If
Final:
End Sub
以上代码返回运行时错误“91”:未设置对象变量或 With block 变量。如何修复此代码以使其正常执行?
最佳答案
在循环中运行 Find 可能会使主代码难以维护,如果您需要在多个位置执行此操作,那么最好的方法是将其分解为单独的函数。
例如。你可以这样做:
sub subname1()
Dim hits as Collection, hit
Set hits = FindAll(Range("credeb"), "crédito")
if hits.Count > 0 then
for each hit in hits
hit.Offset(0, -2).Resize(1,2).Interior.Color = vbYellow
next hit
end if
End Sub
查找所有匹配项的函数:
'return all cells in "rng" which match "val", as a Collection
' (edit the Find method parameters as needed)
Public Function FindAll(rng As Range, val As String) As Collection
Dim rv As New Collection, f As Range
Dim addr As String
'best to be explicit about exactly what you want Find to do...
Set f = rng.Find(what:=val, after:=rng.Cells(rng.Cells.Count), _
LookIn:=xlValues, LookAt:=xlWhole, SearchOrder:=xlByRows, _
SearchDirection:=xlNext, MatchCase:=False)
If Not f Is Nothing Then addr = f.Address()
Do Until f Is Nothing
rv.Add f
Set f = rng.FindNext(after:=f)
If f.Address() = addr Then Exit Do
Loop
Set FindAll = rv
End Function
关于excel - 嵌套 IF 语句后循环不再起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56193118/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!