[英]VBA InStr always returning 0
我正在使用Excel 2010,并尝试创建一个函数,该函数将替换工作表中的部分链接,具体取决于用户的输入。 更具体地说,我尝试替换链接以匹配用户Dropbox的位置。
这是我到目前为止的代码
Private Sub CommandButton1_Click()
Dim DropboxFolder As String
Dim SearchFor As String
Dim SearchPos As Integer
SearchFor = "Dropbox"
With Application.FileDialog(msoFileDialogFolderPicker)
.AllowMultiSelect = False
.Show
On Error Resume Next
DropboxFolder = .SelectedItems(1)
For Each theHyperLink In ActiveSheet.Hyperlinks
SearchPos = InStr(0, SearchFor, theHyperLink.Address, vbBinaryCompare)
theHyperLink.Address = DropboxFolder
Next
Err.Clear
On Error GoTo 0
End With
End Sub
我已经尝试调试代码,并在处添加了一个断点
SearchPos = InStr(0, SearchFor, theHyperLink.Address, vbBinaryCompare)
SearchFor是"Dropbox"
,TheHyperLink.Address是"..\\Dropbox\\Salgdanmarks Salgsakademi\\1\\Ny Microsoft Word Document.docx"
但是SearchPos设置为0
我究竟做错了什么?
我意识到这些评论只是暂时的,因此我将其作为答案。 这也将对将来的访客有所帮助。
Instr
的语法是
InStr([start, ]string1, string2[, compare])
InStr函数语法具有以下参数:
因此,在您的情况下,您需要反转变量。
SearchPos = InStr(1, theHyperLink.Address, SearchFor, vbTextCompare)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.