我正在使用 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)
考虑到我是通过本地函数解析数据以获得最终数据,这似乎效率低下。所以我的问题如下:
附录:
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)