我正在尝试将Google Map API距离矩阵中的数据转换为R.我正在尝试将JSON数据导入R.如何将JSON数据下载到R中,以便稍后我能解析?
require(rjson)
url <- "https://maps.googleapis.com/maps/api/distancematrix/jsonunits=imperial&origins=19+East+34th+Street+NewYork+NY+10016&destinations=40.5177433,-74.2749576&mode=transit&language=fr-FR&key=API_KEY_HERE"
raw.data <- readLines(url, warn = "F")
rd <- fromJSON(raw.data)
我收到此错误:
Error in fromJSON(raw.data) : unexpected character '<'
感谢您的帮助
答案 0 :(得分:0)
我想通过JSONLite如何做到这一点。我正在使用本地&#34; fromJSON&#34; R和那引起了问题。
rd <-jsonlite::fromJSON("Google_API_CALL_IN_HERE", simplifyDataFrame = TRUE)
答案 1 :(得分:0)
恰巧我写了一个可以提供帮助的软件包googleway:
library(googleway)
google_distance(origins = "19 East 34th Street NewYork NY 10016",
destinations = list(c(40.5177433,-74.2749576)),
key = key,
mode = "transit",
language = "fr")
$destination_addresses
[1] "350-356 Lawrie St, Perth Amboy, NJ 08861, États-Unis"
$origin_addresses
[1] "19 E 34th St, New York, NY 10016, États-Unis"
$rows
elements
1 51,3 km, 51305, 1 heure 27 min, 5249, OK
$status
[1] "OK"
同样,设置simplify = FALSE
以获取原始json
google_distance(origins = "19 East 34th Street NewYork NY 10016",
destinations = list(c(40.5177433,-74.2749576)),
key = key,
mode = "transit",
language = "fr",
simplify = FALSE)
[1] "{"
[2] " \"destination_addresses\" : [ \"350-356 Lawrie St, Perth Amboy, NJ 08861, États-Unis\" ],"
[3] " \"origin_addresses\" : [ \"19 E 34th St, New York, NY 10016, États-Unis\" ],"
[4] " \"rows\" : ["
[5] " {"
[6] " \"elements\" : ["
[7] " {"
[8] " \"distance\" : {"
[9] " \"text\" : \"51,3 km\","
[10] " \"value\" : 51305"
[11] " },"
[12] " \"duration\" : {"
[13] " \"text\" : \"1 heure 27 min\","
[14] " \"value\" : 5249"
[15] " },"
[16] " \"status\" : \"OK\""
[17] " }"
[18] " ]"
[19] " }"
[20] " ],"
[21] " \"status\" : \"OK\""
[22] "}"
(simplify == TRUE
使用jsonlite::fromJSON
)