Python 带散点图的底图
Python basemap with scatter plot
我正在尝试在带有散点图的底图上绘制纽约市和柏林的位置。
from mpl_toolkits.basemap import Basemap
import matplotlib.pyplot as plt
import numpy as np
m = Basemap(projection='robin',lon_0=0,resolution='l')
# New York and Berlin
lats = (13.388889,52.516667)
lons = (-74.0059,40.7127)
m.drawcountries(color='#ffffff', linewidth=0.5)
m.fillcontinents(color='#c0c0c0',lake_color='#ffffff')
x, y = m(lons, lats) # transform coordinates
plt.scatter(x, y, 10, marker='o', color='Red')
plt.savefig("filename.svg", figsize=(24,12))
plt.show()
但是,地图上只有一个点显示在错误的位置。
任何人都可以帮助我并指出为什么一个点出现在错误的位置而另一个点完全没有出现吗?
问题是你的坐标定义。您正在混合 longitude
和 latitude
。查了柏林和纽约的坐标,得出如下定义:
# Berlin & New York
lats = [52.516667, 40.730610 ]
lons = [13.388889, -73.935242]
这里是完整的代码:
from mpl_toolkits.basemap import Basemap
import matplotlib.pyplot as plt
import numpy as np
m = Basemap(projection='robin', lon_0=0, resolution='l')
# Berlin & New York
lats = [52.516667, 40.730610 ]
lons = [13.388889, -73.935242]
m.drawcountries(color='#ffffff', linewidth=0.5)
m.fillcontinents(color='#c0c0c0', lake_color='#ffffff')
x, y = m(lons, lats)
plt.plot(x, y, 'bo', color='r', markersize=5)
plt.show()
我正在尝试在带有散点图的底图上绘制纽约市和柏林的位置。
from mpl_toolkits.basemap import Basemap
import matplotlib.pyplot as plt
import numpy as np
m = Basemap(projection='robin',lon_0=0,resolution='l')
# New York and Berlin
lats = (13.388889,52.516667)
lons = (-74.0059,40.7127)
m.drawcountries(color='#ffffff', linewidth=0.5)
m.fillcontinents(color='#c0c0c0',lake_color='#ffffff')
x, y = m(lons, lats) # transform coordinates
plt.scatter(x, y, 10, marker='o', color='Red')
plt.savefig("filename.svg", figsize=(24,12))
plt.show()
但是,地图上只有一个点显示在错误的位置。
任何人都可以帮助我并指出为什么一个点出现在错误的位置而另一个点完全没有出现吗?
问题是你的坐标定义。您正在混合 longitude
和 latitude
。查了柏林和纽约的坐标,得出如下定义:
# Berlin & New York
lats = [52.516667, 40.730610 ]
lons = [13.388889, -73.935242]
这里是完整的代码:
from mpl_toolkits.basemap import Basemap
import matplotlib.pyplot as plt
import numpy as np
m = Basemap(projection='robin', lon_0=0, resolution='l')
# Berlin & New York
lats = [52.516667, 40.730610 ]
lons = [13.388889, -73.935242]
m.drawcountries(color='#ffffff', linewidth=0.5)
m.fillcontinents(color='#c0c0c0', lake_color='#ffffff')
x, y = m(lons, lats)
plt.plot(x, y, 'bo', color='r', markersize=5)
plt.show()