1
我正在嘗試使用google api密鑰將地理編碼反轉爲數據集。我設法運行代碼,並得到想要的結果爲10小樣本,但它給下標越界R中的反向地理編碼循環
Error in rgc$results[[1]] : subscript out of bounds
我設法整合使用下面的代碼API密鑰的錯誤:
` revgx <- mapply(function(latlng, api_key){
url= paste("https://maps.googleapis.com/maps/api/geocode/json?","latlng=",latlng,"&key=",sep="")
rgc <- fromJSON(paste(readLines(url), collapse = ''))
rgc <- rgc$results[[1]]
with(rgc,{rgcdf <<- data.frame(
address = formatted_address
)})
for(k in seq_along(rgc$address_components)){
rgcdf <- cbind(rgcdf, rgc$address_components[[k]]$long_name)
}
names(rgcdf) <- c('address', sapply(rgc$address_components, function(l) l$types[1]))
# return 'more' output
rgcdf
},
y1$latlng)`
我也嘗試過使用與XML相同的方法,但無濟於事。請建議是否需要對代碼進行任何更改。
謝謝@khrm!我運行代碼,它的工作相當準確。但是,當我通過60個查詢時,它給了我一個60開頭的列表。然後,我使用代碼'df1 < - rbindlist(df,fill = TRUE)'來綁定這個列表。這從60列表中刪除了5個結果,因此我無法'與'原始數據集'綁定'來獲取lat,lng和地址字段的數據庫。我得到錯誤'Data.frame中的錯誤(...,check.names = FALSE): 參數意味着行數不同:60,55' –
我添加了valid_latlong。現在你應該可以使用cbind了。如果這有助於接受和贊成。 – khrm
謝謝@ khrm。獲得的列表可以通過'list = rbindlist(lapply(dflist,as.data.table),fill = TRUE)'綁定,並且可以通過'df1 < - cbind(df)與lat-lng的數據框綁定,列表)' –