在 httr 包中使用 POST 请求时获取二进制数据

sac*_*ruk 1 r httr jsonlite

我正在使用 httr 库中的 POST 函数来获取一些数据,代码如下所示。

library(httr)

url = "https://xxxx:xxx@api.xxx/_search" #omitted for privacy
a = POST(url,body = query,encode = "json")
Run Code Online (Sandbox Code Playgroud)

该查询显示在下面的附录中。a$content给了我一大堆十六进制数字,我必须使用另一个函数才能获得一些有用的数据。

最终我希望通过使用获得一个数据框b = fromJSON(a$content)。到目前为止,为了获取任何数据,我必须使用:

chr<-function(n){rawToChar(as.raw(n))}
b = jsonlite::fromJSON(chr(a$content))
data = b$hits$hits$`_source`
Run Code Online (Sandbox Code Playgroud)

考虑到我是通过本地函数解析数据以获得最终数据,这似乎效率低下。所以我的问题如下:

  1. 我是否正确使用 POST 函数来获取查询?
  2. 是否有更有效(更快)的方法将我的数据放入数据框中?

附录:

query = '
{
  "_source": [
    "start","source.country_codes",
    "dest.country_codes"
    ],
    "size": 100,
    "query": {
    "bool": {
    "must": [
    {
    "bool": {
    "must_not": [
    {
    "range": {
    "start": {
    "lte": "2013-01-01T00:00:00"
    }
    }
    },
    {
    "range": {
    "start": {
    "gt": "2016-05-19T00:00:00"
    }
    }
    }
    ]
    }
    }
    ]
    }
  }
}'
Run Code Online (Sandbox Code Playgroud)

小智 5

  1. POST 功能看起来不错。

  2. js<-fromJSON(content(a,as="text"))