VBA在Web字段中输入数据

问题描述 投票:0回答:1

我正在编写vba来打开中央银行的网站并输入值并提取数据,我通常在邮件站点,巴西银行等处进行此操作...

()中央银行

I can not give the input value via vba in the textbox I've already tried:



Ie.Document.all.Item("valueConverter").Innertext="1"
Ie.Document.getElementById("valueConverter").Value="1"
Ie.Document.getElementById("valueConverter")(0).Value="1"
Ie.Document.getElementByName("valueConverter").Value = "1"

这个网站的元素是这样的:

<Input type = "text" name = "valueConverter" maxlength = "17" size "20" value onkeypress = "return (MascaraMoeda (this, '.', ',', Event)

有谁知道怎么样?

html excel vba excel-vba web
1个回答
0
投票

tl;博士

我不能将此标记为副本,因为我没有接受答案,我在哪里发布了类似问题的答案。

不确定协议只是在评论中发布链接并不意味着它会再次被发现。

我的完整答案在这里:Excel Web Query Submit Issues


总结一下:

你可以使用bcb.gov.br Open Data Portal

发送一个JSON回复请求,其转换率来自其汇率 - daily bulletins

通过收到的响应以及其他方法,您可以:

  1. 使用JSON Converter .basa并将响应转换为JSON对象并使用它
  2. 将响应解析为带有正则表达式的字符串以获取值

为简洁起见,我将在这里为您提供第二种方法,您可以查看我对这两种方法的其他答案:

Public Sub GetInfo2()

    Dim strURL As String, strJSON As String, item As Variant, http As Object, json As Object
    Const TARGET_CURRENCY As String = "USD"
    Const START_DATE As String = "06-13-2018"
    Const END_DATE As String = "06-13-2018"

    strURL = "https://olinda.bcb.gov.br/olinda/service/PTAX/version/v1/odata/ExchangeRatePeriod(moeda=@moeda,dataInicial=@dataInicial,dataFinalCotacao=@dataFinalCotacao)?%40moeda=%27" & TARGET_CURRENCY & "%27&%40dataInicial=%27" & START_DATE & "%27&%40dataFinalCotacao=%27" & END_DATE & "%27&%24format=json"

    Set http = CreateObject("MSXML2.XMLHTTP")
    http.Open "GET", strURL, False
    http.send
    strJSON = http.responseText
    Dim Matches As Object
    With CreateObject("VBScript.RegExp")
        .Global = True
        .MultiLine = True
        .IgnoreCase = False
        .Pattern = """cotacaoCompra"":\d{1,}.\d{1,}"  'The pattern I really wanted, "(?<=""cotacaoCompra"":)\d{1,}.\d{1,}", doesn't appear to be supported

        If Not .test(strJSON) Then Exit Sub
        Set Matches = .Execute(strJSON)

        Dim match As Object
        For Each match In Matches
            Debug.Print Replace(match, """cotacaoCompra"":", vbNullString)
        Next
    End With
End Sub
© www.soinside.com 2019 - 2024. All rights reserved.