我有一张纽约市一个社区的薄片地图,使用以下代码生成:
m = folium.Map(location=[40.7035, -73.990],
zoom_start=16.5,
tiles='cartodbpositron')
然后,我尝试使用folium.PolyLine()
在地图上添加连接点的线,但即使在调用m._children
时看到它们被列出,它们也不会显示在地图上。
以下是创建线条的代码,其中G是networkx图:
for x, y in G.edges():
points = [nx.get_node_attributes(G, 'loc')[x], nx.get_node_attributes(G, 'loc')[y]]
egde = folium.PolyLine(locations=points, weight=5, color='red')
edge.add_to(m)
样品point
:
[(-73.986635, 40.703988), (-73.988683, 40.702674)]
m.children
的输出(前几行):
OrderedDict([('cartodbpositron',
<folium.raster_layers.TileLayer at 0x12279feb8>),
('poly_line_ae5785771a2148c5a8559cb0085b10a4',
<folium.vector_layers.PolyLine at 0x122892128>),
('poly_line_ee73b495559940d484064e8c8492eda5',
<folium.vector_layers.PolyLine at 0x1229734a8>),
('poly_line_415a7ed70a2a425e876c8a6711408a6a', ...
知道我可能做错了什么吗?
这有点奇怪,folium折线需要[latitude, longitude]
格式的坐标,而一般接受的格式是[longitude, latitude]
。
让我们举一个例子:我假设您正在使用OSRM来获取几何图形。
OSRM几何图形以[[longitude,latitude],...]
的形式返回坐标。
如果直接将它们与folium一起使用,则不会显示多段线。
使用以下函数反转几何坐标:
def reverse_lon_lat(x):
a = [[p[1], p[0]] for p in x]
return a
并绘制您想要的多段线。