Как использовать Google Geocode API с пакетами адресов - PullRequest
0 голосов
/ 12 мая 2018

Я пытаюсь начать со списка адресов, вызвать Google Geocode API и вернуть соответствующую долготу и широту для каждого адреса. Пока это то, что у меня есть:

import requests
import pandas as pd`
#List of addresses and make dataframe
address1=['100 20th St. Seattle WA','300 Main St. Washington DC','100 Main 
St Richmond VA 23220']`

address1=pd.DataFrame(address1,columns=['Address'])`
#Set up API key
api_key = "XXXXXXXXXXXXXXXXXXXXXXXXXX"
api_response = 
requests.get('https://maps.googleapis.com/maps/api/geocode/json?address= 
{0}&key={1}'.format(address1, api_key))
api_response_dict = api_response.json()`

#create function for calling API
def get_long_lat(address):
  if api_response_dict['status'] == 'OK':
   latitude = api_response_dict['results'][0]['geometry']['location']['lat']
   longitude = api_response_dict['results'][0]['geometry']['location'] 
   ['lng']
   return latitude, longitude `

#attempts a passing the dataframe through the function 

address1['attempt1']=address1.apply(get_long_lat,axis=1)
address1['attempt2'] = address1.apply(lambda x: get_long_lat(x),axis=1)
address1['attempt3']= address1.groupby('Address').apply(get_long_lat)
address1['attempt4']=address1['Address'].apply(get_long_lat)`

output image

Я пытаюсь вызывать функцию строка за строкой, но проблема в том, что она возвращает long и lat для первого адреса и копирует его для других адресов. Это проблема с использованием pandas dataframe или функции .apply или, может быть, с API?

...