vba - & 符号未作为编码字符传入 url

标签 vba excel

我正在使用 Excel 工作簿中单元格中的字符串传递 URL。 该字符串是:Ben & Jerry's 2017 Base PIC - 1。

以下是我在 url 中传递字符串的代码:

Dim targetUrl As String: targetUrl = 

"https://catalina.my.salesforce.com/_ui/search/ui/UnifiedSearchResults?searchType=2&sen=aAh&str=" & i & "#!/initialViewMode=summary"

其中“i”是传递的字符串。

这是在chrome中获取的url:

  https://catalina.my.salesforce.com/_ui/search/ui/UnifiedSearchResults?str=Ben+&+Jerry%27s+2017+Base+PIC+-+1+=&searchType=2&sen=aAh#!/fen=aAh&initialViewMode=detail&str=Ben

如您所见,“&”未进行编码,并且搜索在“Ben”之后不包含任何值。

有人可以指导我如何解决这个问题吗?谢谢。

最佳答案

对参数进行编码:

Sub Test()
  Dim url As String

  url = "https://catalina.my.salesforce.com/_ui/search/ui/UnifiedSearchResults" _
    & "?searchType=2" _
    & "&sen=aAh" _
    & "&str=" & EncodeURL("Ben & Jerry's 2017 Base PIC - 1") _
    & "#!/initialViewMode=summary"

  Debug.Print url
End Sub

Public Function EncodeURL(url As String) As String
  Dim buffer As String, i As Long, c As Long, n As Long
  buffer = String$(Len(url) * 12, "%")

  For i = 1 To Len(url)
    c = AscW(Mid$(url, i, 1)) And 65535

    Select Case c
      Case 48 To 57, 65 To 90, 97 To 122, 45, 46, 95  ' Unescaped 0-9A-Za-z-._ '
        n = n + 1
        Mid$(buffer, n) = ChrW(c)
      Case Is <= 127            ' Escaped UTF-8 1 bytes U+0000 to U+007F '
        n = n + 3
        Mid$(buffer, n - 1) = Right$(Hex$(256 + c), 2)
      Case Is <= 2047           ' Escaped UTF-8 2 bytes U+0080 to U+07FF '
        n = n + 6
        Mid$(buffer, n - 4) = Hex$(192 + (c \ 64))
        Mid$(buffer, n - 1) = Hex$(128 + (c Mod 64))
      Case 55296 To 57343       ' Escaped UTF-8 4 bytes U+010000 to U+10FFFF '
        i = i + 1
        c = 65536 + (c Mod 1024) * 1024 + (AscW(Mid$(url, i, 1)) And 1023)
        n = n + 12
        Mid$(buffer, n - 10) = Hex$(240 + (c \ 262144))
        Mid$(buffer, n - 7) = Hex$(128 + ((c \ 4096) Mod 64))
        Mid$(buffer, n - 4) = Hex$(128 + ((c \ 64) Mod 64))
        Mid$(buffer, n - 1) = Hex$(128 + (c Mod 64))
      Case Else                 ' Escaped UTF-8 3 bytes U+0800 to U+FFFF '
        n = n + 9
        Mid$(buffer, n - 7) = Hex$(224 + (c \ 4096))
        Mid$(buffer, n - 4) = Hex$(128 + ((c \ 64) Mod 64))
        Mid$(buffer, n - 1) = Hex$(128 + (c Mod 64))
    End Select
  Next

  EncodeURL = Left$(buffer, n)
End Function

关于vba - & 符号未作为编码字符传入 url,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49497725/

相关文章:

Excel VBA : Range gives Argument Not Optional error message

excel - 在 VBA 中将特定的 CSV 添加到工作簿

excel - 无法更新 EXCEL VBA 中的 ADO 记录集

Python读取Excel单元格数据验证

VBA Excel如何用另一个单元格值替换值的一部分

excel - 如何解锁图表并禁止切割?

excel - 如何查找后期绑定(bind)引用的名称

excel - 如何使用 VBA 超越 Windows 对话框

arrays - 无法使用数组成员变量分配数组

vba - 代码有错误 : unable to get the vlookup property of the worksheetfunction class