gpt4 book ai didi

python - 如何从经纬度坐标列表中获取城市、州和国家?

转载 作者:行者123 更新时间:2023-12-05 01:57:11 27 4
gpt4 key购买 nike

我有 500,000 个纬度和经度坐标列表,如下所示:

Latitude   Longitude  
42.022506 -88.168156
41.877445 -87.723846
29.986801 -90.166314

我希望使用 python 获取新列中每个坐标的城市、州和国家/地区,如下所示:

Latitude   Longitude   City        State   Country
42.022506 -88.168156 Streamwood IL United States
41.877445 -87.723846 Chicago IL United States
29.986801 -90.166314 Metairie LA United States

对于这么大的数据集,如何在 python 中实现?我听说过 Google 的 API、Nominatim 的 API 和 Geopy 包。

如何将所有行都运行到这段代码中?现在我必须在最后一行手动输入纬度和经度。

import csv 
import pandas as pd
import numpy as np
import math
from geopy.geocoders import Nominatim

input_file = "Lat-Log.csv" # file contains ID, Latitude, Longitude
output_file = "output.csv"
df = pd.read_csv(input_file)

geolocator = Nominatim(user_agent="geoapiExercises")
def city_state_country(coord):
location = geolocator.reverse(coord, exactly_one=True)
address = location.raw['address']
city = address.get('city', '')
state = address.get('state', '')
country = address.get('country', '')
return city, state, country
print(city_state_country("47.470706, -99.704723"))

输出结果为('Bowdon'、'North Dakota'、'USA')。我希望用我的列(纬度和经度)替换坐标以运行我的列表。如何将我的列输入到代码中以运行整个文档?

最佳答案

您想在每一行上运行一个函数,这可以使用 apply() 来完成.

有两个问题,即您想要 1) 为函数提供多个参数,以及 2) 取回多个结果。

这些问题解释了如何做那些事情:

以下是调整代码以执行此操作的方法:

import pandas as pd
import io
from geopy.geocoders import Nominatim
geolocator = Nominatim(user_agent="geoapiExercises")

s = """Latitude Longitude
42.022506 -88.168156
41.877445 -87.723846
29.986801 -90.166314"""

df = pd.read_csv(io.StringIO(s), delim_whitespace=True)

def city_state_country(row):
coord = f"{row['Latitude']}, {row['Longitude']}"
location = geolocator.reverse(coord, exactly_one=True)
address = location.raw['address']
city = address.get('city', '')
state = address.get('state', '')
country = address.get('country', '')
row['city'] = city
row['state'] = state
row['country'] = country
return row

df = df.apply(city_state_country, axis=1)
print(df)

(我用数据帧的内联定义替换了您的 read_csv() 调用。忽略它。这对示例并不重要。我这样做是为了使示例独立。)

数据帧的每一行都会调用 city_state_country() 函数。 (axis=1 参数使 apply() 使用行而不是列运行。)该函数获取纬度和经度,并进行查询。然后,它修改行以包含来自查询的信息。

这会得到以下结果:

    Latitude  Longitude     city      state        country
0 42.022506 -88.168156 Illinois United States
1 41.877445 -87.723846 Chicago Illinois United States
2 29.986801 -90.166314 Louisiana United States

与您的示例不同,但 Nominatim 似乎没有为您的两个坐标返回一个城市。 (它称它们为城镇,而不是城市。)

关于python - 如何从经纬度坐标列表中获取城市、州和国家?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69409255/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com