gpt4 book ai didi

vba - 匹配整个单词/短语并替换

转载 作者:行者123 更新时间:2023-12-04 22:08:06 25 4
gpt4 key购买 nike

我正在尝试用另一个字符串替换一个字符串,但问题是该字符串部分匹配其他字符串。

我正在尝试创建一个函数来搜索另一个电子表格中的每一行并在找到我的搜索短语时返回该行。当与较长的单词或独特的单词一起使用时,脚本的效果非常好,或者我输入代码短语作为搜索条件。问题是,如果字符串部分匹配其他字符串,它会被复制,我会得到很多错误的结果。

我需要该功能停止在单词中查找结果,而是将单词或短语作为一个整体来查找以进行匹配。

到目前为止,这是我的脚本:

Sub Light()
Dim rng1 As Range
Dim fnd1 As String
fnd1 = "Quantity"

Sheets("TEST").Activate
Set rng1 = Sheets("TEST").Cells.Find(fnd1)
If Not rng1 Is Nothing Then
Range(Cells(rng1.Row, rng1.Column), Cells(Rows.Count, rng1.Column).End(xlUp)).Copy _
Sheets("TEMPLATE").Range("A5")
Cells(1, 1).Select
End If

在这里我遇到了问题,因为第二个搜索条件部分满足并被复制。
  Dim rng2 As Range
Dim fnd2 As String
fnd2 = "Quantity order min"
Sheets("TEST").Activate
Set rng2 = Sheets("TEST").Cells.Find(fnd2)
If Not rng2 Is Nothing Then
Range(Cells(rng2.Row, rng2.Column), Cells(Rows.Count, rng2.Column).End(xlUp)).Copy _
Sheets("TEMPLATE").Range("C5")
Cells(1, 1).Select
End If

最佳答案

肯定会有更好的答案,这甚至可能无法达到您想要的结果 - 但到目前为止还没有其他任何东西!:

Sub Light()
Dim rng1 As Range
Dim fnd1 As String
Dim rng2 As Range
Dim fnd2 As String

fnd1 = "Quantity"
fnd2 = "Quantity order min"

Sheets("TEST").Activate
Set rng1 = Sheets("TEST").Cells.Find(fnd1)
If Not rng1 Is Nothing Then
If Sheets("TEST").Cells.Find(fnd1, LookIn:=xlValues, lookat:=xlWhole) > 1 Then
Sheets("TEMPLATE").Select
Range("A5").Select
ActiveCell.FormulaR1C1 = fnd1
End If
End If
Sheets("TEST").Activate
Set rng2 = Sheets("TEST").Cells.Find(fnd2)
If Not rng2 Is Nothing Then
If Sheets("TEST").Cells.Find(fnd2, LookIn:=xlValues, lookat:=xlWhole) > 1 Then
Sheets("TEMPLATE").Select
Range("C5").Select
ActiveCell.FormulaR1C1 = fnd2
End If
End If
End Sub

关于vba - 匹配整个单词/短语并替换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16503488/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com