У меня есть файл excel с информацией о некоторых городах, теперь я хочу нанести эти города с их названиями на карту. Я написал следующие коды, однако я не могу правильно назвать названия. Для каждого цитирования я получаю ярлык со всем списком «имя». Любое предложение приветствуется.
#Я не смог установить ни PyGMT, ни базовую карту, ни даже геопанды, поэтому у меня просто картопия.
import pandas as pd
import csv
import matplotlib.pyplot as plt
import cartopy.crs as ccrs
import cartopy.feature as cfeature
df = pd.read_excel('./seismogram.xlsx')
lon = df['longitude'].to_list()
lat = df['latitude '].to_list()
name = (df['code']).to_list()
def main():
fig = plt.figure(figsize=(15,15))
plt.rcParams["font.size"] = 18
ax = fig.add_subplot(1,1,1, projection=ccrs.PlateCarree())
ax.set_extent([128, 133, 30, 35], crs=ccrs.PlateCarree())
ax.set_title("Japan")
ax.coastlines(resolution='10m')
ax.add_feature(cfeature.BORDERS, linestyle=':')
ax.stock_img()
return fig, ax
fig, ax = main()
ax.scatter(lon, lat, color = "r", marker = "o", s = 15)
zip_object = zip(lon, lat, name)
for (lg, lt, ne) in zip_object:
ax.text(lg - .05, lt + .05,
name,
va='center',
ha='right', transform=ccrs.Geodetic(), fontweight='bold')
plt.show()
Из вашего цикла for я на 99% уверен, что вы должны использовать ne
вместо name
:
zip_object = zip(lon, lat, name)
for (lg, lt, ne) in zip_object:
ax.text(lg - .05, lt + .05,
ne,
va='center',
ha='right', transform=ccrs.Geodetic(), fontweight='bold')
Легко ошибиться :)
Извините, что отнимаю ваше время, вы правы на 100%.
В чем проблема? Пожалуйста, покажите участок, который вы получили.