Я использовал Google Geocoding API для запроса данных о местоположении для тысяч адресов. Содержание каждого запроса было проанализировано как список. Полученный список был добавлен в столбец «get_response».
У меня большие трудности при извлечении отдельных атрибутов из этих списков с помощью пакета purrr, и я надеялся, что вы, замечательные люди, могли бы помочь.
library(tidyverse)
#> Warning: package 'tidyverse' was built under R version 3.5.3
l1 <- list(results = list(list(geometry = list(location = list(lat = 41.9, lng = -87.6)))), status = "OK")
l2 <- list(results = list(list(geometry = list(location = list(lat = 35.1, lng = -70.6)))), status = "OK")
starting_df <- tribble(~name, ~get_response,
"first_location", l1,
"second_location", l2)
print(starting_df)
#> # A tibble: 2 x 2
#> name get_response
#> <chr> <list>
#> 1 first_location <named list [2]>
#> 2 second_location <named list [2]>
Ниже я продемонстрирую, как я могу извлечь атрибут по одному:
pluck(starting_df[1,]$get_response, 1, "results", 1, "geometry", "location", "lat")
#> [1] 41.9
pluck(starting_df[2,]$get_response, 1, "results", 1, "geometry", "location", "lat")
#> [1] 35.1
Это мой желаемый вывод:
desired_output <- tribble(~name, ~get_response, ~lat,
"first_location", l1, 41.9,
"second_location", l2, 35.1)
print(desired_output)
#> # A tibble: 2 x 3
#> name get_response lat
#> <chr> <list> <dbl>
#> 1 first_location <named list [2]> 41.9
#> 2 second_location <named list [2]> 35.1
Это моя попытка использовать purrr :: map
new_df <- mutate(starting_df, lat = map(get_response, pluck(1, "results", 1, "geometry", "location", "lat")))
#> Error: Can't convert NULL to function
Создано в 2020-04-18 пакетом Представить (v0.3.0)
Кто-нибудь знает хороший способ сделать это?