0

我有一个带有位置的数据框,我想在一个可管道的解决方案中从 Google Places 向它们附加电话号码和网站

我最接近的方法是使用googleway,取消列出 JSON 并使用正则表达式提取地点 ID,然后对电话号码和电子邮件地址再次执行相同操作。有没有更有针对性的方法来做到这一点?

library(googleway)
library(tidyverse)

set_key("api")

index_no <- c(1,2,3,4)
landmark<- c("Sydney Opera House","Eiffel Tower","Empire State Building","Big Ben")
df <- data.frame(index_no,landmark, stringsAsFactors = F)

df %>%
  rowwise() %>%
  # Place IDs are required for the function beneath
  do(data.frame(., place_id  = unlist(google_places(search_string = .$landmark)))) %>%
  # Place IDs are 27 chars
  filter(grepl("^\\S{27}$", place_id )) %>%
  do(data.frame(., details = unlist(google_place_details(place_id  = .$place_id )))) %>%
  unique() %>%
  # Gets non-Google URls and Phone Numbers
  filter(grepl("(?!.*(google|maps))(^https?.*|^\\+\\d)", details, perl = T )) %>%
  group_by(landmark) %>%
  mutate(seq = 1:n()) %>%
  spread(seq, details) %>%
  rename(phone_number = `1`, website = `2`) %>%
  select(-place_id) %>%
  ungroup()
4

1 回答 1

1

我怀疑有。这是 Google API 方面的一个两步过程(请参阅文档:https ://developers.google.com/places/web-service/details ):

你需要 :

  • 获得唯一的placeid(通过地方搜索调用)
  • 获取您的联系方式placeid(通过 Place Details 电话)

如果您自己粘贴您的 url 并通过 httr 执行它(Google API 以破坏性更改而闻名,并且 R 包很难跟上),您可能对这个过程有更多的控制权,并且您可以将丑陋的代码包装在您的自己的函数,使调用整洁 - 但最终它必须是 2 个 API 调用。

于 2019-06-12T16:56:57.503 回答