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